Strut2拦截器Interceptorლ(╹◡╹ლ)

本文介绍了Struts2中拦截器的基本概念及分类,并详细解释了如何自定义拦截器,包括配置过程和代码实现,最后给出一个登录过滤的示例。

拦截器可以在用户请求Struts的Action时的前或后,进行一些业务处理。拦截器可以是1或N个。

在Struts2中,Interceptor的拦截类型,分成以下三类:

1. before

before拦截,是指在拦截器中定义的代码,它们存在于invocation.invoke()代码执行之前。这些代码,将依照拦截器定义的顺序,顺序执行。

2. after

after拦截,是指在拦截器中定义的代码,它们存在于invocation.invoke()代码执行之后。这些代码,将一招拦截器定义的顺序,逆序执行。

3. PreResultListener

有的时候,before拦截和after拦截对我们来说是不够的,因为需要在Action执行完之后,但是还没有回到视图层之前,做一些事情。Struts2同样支持这样的拦截,这种拦截方式,是通过在拦截器中注册一个PreResultListener的接口来实现.

ლ(╹◡╹ლ)以上摘抄自百度~

strut2自定义拦截器很简单,步骤也很少~

首先、在struts.xml文件中注册拦截器,新建一个栈需要把默认拦截器也引进去~

<!-- 注册拦截器 -->
    	<interceptors>
    		<!-- 自定义的拦截器 -->
    		<interceptor name="myInterceptor" class="com.web.interceptor.MyInterceptor"></interceptor>
    		<interceptor-stack name="myStack">
    			<interceptor-ref name="myInterceptor"></interceptor-ref>
    			<interceptor-ref name="defaultStack"></interceptor-ref>
    		</interceptor-stack>
    	</interceptors>
    	<!-- 覆盖默认拦截器的引用 -->
		<default-interceptor-ref name="myStack"/>
		<global-results>
			<result name="index" type="redirectAction">
				<param name="namespace">/</param>
				<param name="actionName">/success.jsp</param>
			</result>
		</global-results>

 自定义拦截器的类,实现com.opensymphony.xwork2.interceptor.Interceptor的接口及其方法~intercept方法为拦截处理ai.invoke()为不拦截←我是这么理解的_(:зゝ∠)_

 

public class MyInterceptor implements Interceptor{
	private static final long serialVersionUID = -649966144489142691L;
	
	public void destroy() {
		
	}
	public void init() {
		
	}
	public String intercept(ActionInvocation ai) throws Exception {
		System.out.println(">>>>>>> Interceptor >>>>>> ");
		//从session中读取登录信息
		Map<String,Object> session = ai.getInvocationContext().getSession();
		if(session.get("user") != null){
			System.out.println(">> pass >>");
			return ai.invoke();							
		}else{
			System.out.println(">> forbidden >>");
			return "index";
		}
	}
 这例子用作登录过滤~当然也能用在其他功能上~

 

PS:<global-results>的标签是一个全局<result>,当一个action返回的String没有对应的result,就会去找这个标签~这里是用于响应拦截器的( ̄ε(# ̄)☆╰╮o( ̄皿 ̄///)

 

【无人机】基于改进粒子群算法的无人机路径规划研究[和遗传算法、粒子群算法进行比较](Matlab代码实现)内容概要:本文围绕基于改进粒子群算法的无人机路径规划展开研究,重点探讨了在复杂环境中利用改进粒子群算法(PSO)实现无人机三维路径规划的方法,并将其与遗传算法(GA)、标准粒子群算法等传统优化算法进行对比分析。研究内容涵盖路径规划的多目标优化、避障策略、航路点约束以及算法收敛性和寻优能力的评估,所有实验均通过Matlab代码实现,提供了完整的仿真验证流程。文章还提到了多种智能优化算法在无人机路径规划中的应用比较,突出了改进PSO在收敛速度和全局寻优方面的优势。; 适合人群:具备一定Matlab编程基础和优化算法知识的研究生、科研人员及从事无人机路径规划、智能优化算法研究的相关技术人员。; 使用场景及目标:①用于无人机在复杂地形或动态环境下的三维路径规划仿真研究;②比较不同智能优化算法(如PSO、GA、蚁群算法、RRT等)在路径规划中的性能差异;③为多目标优化问题提供算法选型和改进思路。; 阅读建议:建议读者结合文中提供的Matlab代码进行实践操作,重点关注算法的参数设置、适应度函数设计及路径约束处理方式,同时可参考文中提到的多种算法对比思路,拓展到其他智能优化算法的研究与改进中。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值