struts拦截器配置
很多同学在进行编程学习时缺乏系统学习的资料。本页面基于struts拦截器配置内容,从基础理论到综合实战,通过实用的知识类文章,标准的编程教程,丰富的视频课程,为您在struts拦截器配置相关知识领域提供全面立体的资料补充。同时还包含 safari浏览器、samba、SAMP 的知识内容,欢迎查阅!
struts拦截器配置相关知识
-
Struts 拦截器介绍 实现aop的方式 用于实现action之前,之后执行 一般用于事物操作. 一般用于对某些未授权的页面访问的时候,进行拦截操作,拦截非法访问. 开箱即用拦截器 <!-- 拦截器 --> <interceptor-ref name="params"/> <!-- 传递属性拦截器 --> <interceptor-ref name="timer"/> <!-- 测算执行时间 --> 必须有传递属性这个拦截器 运行输出日志如下 2019-03-24 03:50:19.231 [DEBUG] com.opensymphony.xwork2.ognl.SecurityMemberAccess.isAccessible(SecurityMemberAccess.java:67
-
Struts2【拦截器】知识要点tags: Struts2 什么是拦截器 拦截器Interceptor.....拦截器是Struts的概念,它与过滤器是类似的...可以近似于看作是过滤器 为什么我们要使用拦截器 前面在介绍Struts的时候已经讲解过了,Struts为我们实现了很多的功能,比如数据自动封装阿..文件上传功能阿....Struts为我们提供的这些功能都是通过拦截器完成的...... 数据自动封装通过<interceptor name="params" class="com.opensymphony.xwork2.interceptor.ParametersInterceptor"/>这个拦截器。 文件上传通过<interceptor name="f
-
SpringMVC拦截器配置拦截器顾名思义就是用于拦截访问请求的,我们可以在拦截器里对访问请求进行事先的处理,例如权限检查、记录日志、验证请求数据等等。说白了就是我们可以在请求到控制器之前对其进行一个处理。拦截器基本上和过滤器是类似的,只不过拦截器提供的方法比较实用,参数也比较多,而且拦截器是受到spring容器的管理的。实现拦截器很简单,只需要实现spring里的HandlerInterceptor接口并实现接口中的三个方法即可,如下示例:package org.zero01.test;import org.springframework.web.servlet.HandlerInterceptor;import org.springframework.web.servlet.ModelAndView;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletRespo
-
在springmvc的配置文件中,配置springmvc拦截器拦截特定的请求//在SpringMVC的配置文件中配置 <mvc:interceptors> <mvc:interceptor> //拦截路径为/mvc/**的请求 <mvc:mapping path="/mvc/**"/> //注入拦截器所在的类 <bean class="test.SpringMVC.Interceptor.MyInterceptor"></bean> </mvc:interceptor> </mvc:interceptors>
struts拦截器配置相关课程
struts拦截器配置相关教程
- 2.4 配置拦截器 上一步我们开发了配置器类,如果想让配置器生效,还需要通过配置类进行相应配置。实例:/** * Web配置类 */@Configurationpublic class WebConfig implements WebMvcConfigurer { /** * 添加Web项目的拦截器 */ @Override public void addInterceptors(InterceptorRegistry registry) { // 对所有访问路径,都通过MyInterceptor类型的拦截器进行拦截 registry.addInterceptor(new MyInterceptor()).addPathPatterns("/**"); }}
- 3.3 拦截器链 所谓拦截器链,指多个拦截器一起协作工作,拦截器一起工作时,请注意拦截器中的各个方法之间的调用顺序。前面拦截器的 preHandle 方法的返回值会影响后面的拦截器和控制器是否正常工作:如果返回 true 表示继续流程,可继续调用下一个拦截器或进入控制器;如果返回 false 表示流程中断,如登录身份检查失败。不会继续调用其他的拦截器或处理器。Tips : 如果第一个拦截器的 preHandle 方法返回 true,则会进入第二个拦截器。如果第二个拦截器的 preHandle 方法 返回 false,则直接进入第一个拦截器的 afterCompletion 方法。
- 3. AspectJ 安全拦截器 AspectJ 安全拦截器和 AOP 联盟安全拦截器类似,但仍有一些不同。AspectJ 安全拦截器的应用类名为 AspectJSecurityInterceptor。不同于 AOP 联盟安全拦截器,它不是基于 Spring 应用上下文来激活拦截器,它通过 AspectJ 编译器实现。多数情况下,同一应用会出现这两种安全拦截器,AspectJ 用于域对象的安全控制,AOP 联盟安全拦截器用于服务层的安全。AspectJSecurityInterceptor 的配置方式如下:<bean id="bankManagerSecurity" class= "org.springframework.security.access.intercept.aspectj.AspectJMethodSecurityInterceptor"><property name="authenticationManager" ref="authenticationManager"/><property name="accessDecisionManager" ref="accessDecisionManager"/><property name="afterInvocationManager" ref="afterInvocationManager"/><property name="securityMetadataSource"> <sec:method-security-metadata-source> <sec:protect method="com.mycompany.BankManager.delete*" access="ROLE_SUPERVISOR"/> <sec:protect method="com.mycompany.BankManager.getBalance" access="ROLE_TELLER,ROLE_SUPERVISOR"/> </sec:method-security-metadata-source></property></bean>可见,除了类名之外,AspectJ 方式与 AOP 联盟方式配置几乎一样。不仅如此,这两个拦截器可以共用 securityMetadataSource 对象。下一步,我们需要定义 AspectJ 的 aspect,例如:package org.springframework.security.samples.aspectj;import org.springframework.security.access.intercept.aspectj.AspectJSecurityInterceptor;import org.springframework.security.access.intercept.aspectj.AspectJCallback;import org.springframework.beans.factory.InitializingBean;public aspect DomainObjectInstanceSecurityAspect implements InitializingBean { private AspectJSecurityInterceptor securityInterceptor; pointcut domainObjectInstanceExecution(): target(PersistableEntity) && execution(public * *(..)) && !within(DomainObjectInstanceSecurityAspect); Object around(): domainObjectInstanceExecution() { if (this.securityInterceptor == null) { return proceed(); } AspectJCallback callback = new AspectJCallback() { public Object proceedWithObject() { return proceed(); } }; return this.securityInterceptor.invoke(thisJoinPoint, callback); } public AspectJSecurityInterceptor getSecurityInterceptor() { return securityInterceptor; } public void setSecurityInterceptor(AspectJSecurityInterceptor securityInterceptor) { this.securityInterceptor = securityInterceptor; } public void afterPropertiesSet() throws Exception { if (this.securityInterceptor == null) throw new IllegalArgumentException("securityInterceptor required"); } }}这段代码中,安全拦截器被应用每一个 PersistableEntity 实例。AspectJCallback 被用于执行 proceed() ,该调用只有在 around() 方法中才能得以执行,当我们需要目标对象继续执行时,这些匿名的回调函数会被调用。下一步,我们需要配置 Spring 加载 aspect 并关联到 AspectJSecurityInterceptor 拦截器中,如下:<bean id="domainObjectInstanceSecurityAspect" class="security.samples.aspectj.DomainObjectInstanceSecurityAspect" factory-method="aspectOf"><property name="securityInterceptor" ref="bankManagerSecurity"/></bean>到这里为止,我们可以随意的创建自己的 bean 对象了,他们都将被安全拦截器覆盖。
- 3. 自定义拦截器 Spring MVC 内置有很多拦截器。这些拦截器提供的功能,基本上能够满足开发者完成常规开发。但是,需求总是瞬息变化的,开发者可以根据自己的业务需求自定义拦截器。
- 3.1 拦截器接口规范 自定义拦截器之前,首先要了解 Spring MVC 提供的拦截器接口,自定义拦截器必须遵循此接口规范。public interface HandlerInterceptor { /** * 用户控制器之前拦截,实现用户控制器数据的预处理工作,第三个参数为响应的用户控制器 */ default boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { return true; } /** *对用户控制器处理后的数据再进一步处理 */ default void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable ModelAndView modelAndView) throws Exception { } /** * 视图解析器对 View 渲染完成后对最后结果进行处理 */ default void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable Exception ex) throws Exception { }}Spring MVC 提供有拦截器适配器,适配器对拦截器接口做了简单封装。public abstract class HandlerInterceptorAdapter implements AsyncHandlerInterceptor{ //……}
- 2. 拦截器的概念 拦截器是什么?拦截器就是一个功能模块,工作模式决定了其与众不同:非侵入式: Spring MVC 的拦截器是 AOP 编程思想的实际应用,可以在不影响服务对象代码结构的条件下提供附加功能;动态装配、拆卸: 需要时就装配,不需要时可拆卸。与被服务的对象之间具有极低的耦合度。
struts拦截器配置相关搜索
-
s line
safari浏览器
samba
SAMP
samplerate
sandbox
sanitize
saper
sas
sass
save
smarty模板
smil
smtp
snapshot
snd
snmptrap
soap
soapclient
soap协议