Struts2框架使用及原理及其拦截器解析

7 篇文章 0 订阅

Struts是当前非常流行且稳定的基于MVC设计模式的Web应用程序框架,使用它的目的就是帮助我们更加灵活开发Web应用,以及节省开发时间。

Struts2并不是一个全新的框架,早在2001年就已经出现了Struts1,然后又基于WebWork框架开发出了Struts2,所以Struts的稳定性,成熟度都是相当可靠的,并且结合了Struts1及WebWork的优点

Struts2使用了Annotation(注解)方面的知识

下载Struts2的jar包网站:http://struts.apache.org/ 历史版本下载地址:http://archive.apache.org/dist/

使用Struts2步骤:

1.创建了web项目之后,导入相应的Struts2的jar包后,就要对web.xml文件进行配置,其中最关键的就是配置过滤器,如下:

<filter> <!--过滤器-->
    <filter-name>struts2</filter-name>
    <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
  </filter>
  <filter-mapping> <!--过滤器映射-->
    <filter-name>struts2</filter-name>
    <url-pattern>/*</url-pattern> <!--对所有路径都过滤-->
  </filter-mapping>

MVC框架都需要与web应用整合,这就不得不借助于web.xml配置文件,只有在web.xml文件中Servlet才会被应用加载。

通常,所有的MVC框架都需要web应用加载一个核心控制器,那么在Struts2中,需要加载StrutsPrepareAndExecuteFilter,只要web应用加载,StrutsPrepareAndExecuteFilter,StrutsPrepareAndExecuteFilter将会加载Struts2框架

因为Struts2将核心控制器设置成Filter而不是Servlet

2.创建Struts2的配置文件,struts.xml 在这里配置相应的映射 如:

要定义相应的包

<package name="adminBasePkg" namespace="/admin" extends="json-default">

<!--包里的action及result可在代码用使用注解实现-->

</package>

比如:在类名称上加上注解:

@Namespace("/admin/adminclassManager")
@ParentPackage("adminBasePkg")

在具体的action方法上加上注解:

@Action(value="classManager",results={
@Result(name="classManager",location="/admin/adminclassManager/classManager.jsp")})

action方法返回字符串为:return "classManager"

result属性里还有location属性,用来定位该视图资源的位置,上面也已经给出了例子

同是result还可以用多个result来表达多种不同的返回结果,如:

@Results({
@Result(name="0_index",location = "/admin/adminIndex.jsp"),
@Result(name="1_index",location = "/teacher/teacherIndex.jsp"),
@Result(name="2_index",location = "/student/studentIndex.jsp"),
@Result(name="input",location = "/login.jsp"), //验证账号密码
@Result(name=com.opensymphony.xwork2.Action.ERROR,location = "/500.jsp")
})

上面的Namespace及Action及Result命名视具体情况而定

各种拦截器的配置也是在这里配置

还有以下配置可按具体情况添加:

<!-- 请求参数的编码方式--> 
    <constant name="struts.i18n.encoding" value="UTF-8"/> 
    <!-- 指定被struts2处理的请求后缀类型。多个用逗号隔开--> 
    <constant name="struts.action.extension" value="action,do,htm"/> 
    <!-- 当struts.xml改动后,是否重新加载。默认值为false(生产环境下使用),开发阶段最好打开  --> 
    <constant name="struts.configuration.xml.reload" value="true"/> 
    <!-- 是否使用struts的开发模式。开发模式会有更多的调试信息。默认值为false(生产环境下使用),开发阶段最好打开  --> 
    <constant name="struts.devMode" value="true"/>   
    <!-- 设置浏览器是否缓存静态内容。默认值为true(生产环境下使用),开发阶段最好关闭  --> 
    <constant name="struts.serve.static.browserCache" value="false" /> 
    <!-- 是否开启动态方法调用--> 
    <constant name="struts.enable.DynamicMethodInvocation" value="false"/>  

3.struts.properties文件:是Struts的全局 属性文件,自动加载。该文件包含很多key-value对,该文件完全可以配置在struts.xml中,使用constant元素

4.设计一个所有Action的父类,继承ActionSupport

Struts2工作原理图:


通过文字来表述该过程就是:用户通过页面发送HttpServletRequest向Servlet容器即Tomacat(或者使用其它)提交一个请求,这个请求会经过一系列的过滤器,可以是自定义也可以使用Struts2的,最终会被著名的Struts2过滤器StrutsPrepareAndExecuteFilter核心控制器拦截,核心控制器会访问ActionMapper来决定是否要调用某一个Action,如果用户请求的是jsp页面或其它与action无关的资源,则不会访问action,如果判断用户要访问Action,则ActionMapper会告诉核心控制器,然后核心控制器会将控制器委派为ActionProxy,然后该代理会通过Configuration Manager来加载配置文件即Struts.xml来找到需要调用的Action,找到之后ActionProxy会创建Action Invocation实例,里面包括了所需要创建的Action实例,以及一系列的拦截器,在调用Action之前,会按顺序执行一系列拦截器,再调用Action中的业务处理,然后方法返回一个结果,通常是字符串,该字符串根据result与某一jsp页面对应或者再调用某个Action,这时还需要按逆序来重新执行一遍拦截器,才会进行最后的通过HttpServletResponse来响应用户。

Struts2提供了三种方式去访问Servlet API

1.ActionContext

2.实现ServletRequestAware, ServletResponseAware, ServletContextAware接口

3.ServletActionContext

动态方法调用

1.指定method(不常用)

2.感叹号方式(不常用)

3.通配符方式(常用)

通过注解来实现action的配置更为方便

后台获取jsp参数的方法:

1.使用Action的属性接收参数

2.使用DomainModel接收参数

3.使用Model Driven接收参数(常用)

表单验证

通过validate()方法可以对登录等请求进行验证,然后在jsp页面通过

<div>
<s:fielderror/> <!-- 显示表单验证的出错信息 -->
</div>

Struts2处理流程


Struts2的拦截器:

Struts2的很多核心功能都是通过拦截器实现的,例如数据转移、数据校验、数据转换等

拦截器方法在Action执行之前和之后都会涉及

通过拦截器栈可以将过个拦截器组合在一起


定义拦截器的方法

1.创建一个拦截器类实现Interceptor接口(少用)

2.创建一个拦截器类继承AbstractInterceptor类(常用),提供了init()和destroy()方法空实现,只需实现intercept()即可

在Struts.xml文件中配置拦截器,如:

<interceptors>
<interceptor name="systemInterceptor" class="packageName.SystemInterceptor"></interceptor>
</interceptors> 

然后在需要用到拦截器的Action中,添加注解

@Action(interceptorRefs={@InterceptorRef("systemInterceptor")})

Struts2的内建拦截器:

1.params:负责将请求参数转化为Action的属性值

2.staticParams:将配置文件中Action的子元素params参数设置为Action属性

3.ServletConfig:将源于Servlet API各种对象注入到Action中,必须实现对应接口(ServletRequestAware, ServletResponseAware, ServletContextAware

4.fileUpload拦截器:实现文件上传,将文件及其元数据设置到Action中

5.exception拦截器:将异常信息映射到用户自定义的页面

6.validation拦截器:数据验证

如果不定义拦截器,则会默认调用默认拦截器栈:

<interceptors-ref name = "defaultStact"></interceptors-ref> 

注意:如果自己手动引用了其它拦截器蓝,则默认拦截器栈就不会调用,所以建议在自己引用的拦截器前添加上默认的拦截器栈

以上便是个人见解,欢迎讨论




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Struts2使用Convention插件配置权限拦截器,可以按照以下步骤操作: 1. 在`struts.xml`文件中配置一个拦截器栈,例如: ```xml <struts> <constant name="struts.convention.action.packages" value="com.example.actions"/> <package name="default" extends="struts-default"> <interceptors> <interceptor-stack name="myStack"> <interceptor-ref name="authInterceptor"/> <interceptor-ref name="defaultStack"/> </interceptor-stack> </interceptors> </package> </struts> ``` 2. 定义一个权限拦截器`authInterceptor`,例如: ```xml <struts> <constant name="struts.convention.action.packages" value="com.example.actions"/> <package name="default" extends="struts-default"> <interceptors> <interceptor-stack name="myStack"> <interceptor-ref name="authInterceptor"/> <interceptor-ref name="defaultStack"/> </interceptor-stack> <interceptor name="authInterceptor" class="com.example.interceptors.AuthInterceptor"/> </interceptors> </package> </struts> ``` 3. 在`com.example.interceptors.AuthInterceptor`类中实现权限验证逻辑,例如: ```java public class AuthInterceptor extends AbstractInterceptor { @Override public String intercept(ActionInvocation invocation) throws Exception { // 获取当前请求的Action和方法名 String actionName = invocation.getProxy().getActionName(); String methodName = invocation.getProxy().getMethod(); // 根据Action和方法名判断是否需要进行权限验证 boolean needAuth = checkNeedAuth(actionName, methodName); // 如果需要权限验证,则进行验证 if (needAuth) { // TODO: 实现权限验证逻辑 // 如果权限验证不通过,则返回一个特定的结果 return "authFailed"; } else { // 如果不需要权限验证,则直接执行Action return invocation.invoke(); } } private boolean checkNeedAuth(String actionName, String methodName) { // TODO: 根据Action和方法名判断是否需要进行权限验证 return true; } } ``` 4. 在需要进行权限验证的Action类或方法上添加`@InterceptorRefs`注解,指定使用拦截器栈,例如: ```java @Namespace("/admin") @InterceptorRefs("myStack") public class AdminAction extends ActionSupport { @Action("/listUsers") public String listUsers() { // TODO: 实现列出用户列表的业务逻辑 return SUCCESS; } } ``` 这样,当用户访问`/admin/listUsers`,就会先被`authInterceptor`拦截器拦截,进行权限验证,如果验证通过,则执行`listUsers`方法,否则返回`authFailed`结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值