关于Struts2实现简单权限拦截功能

需求:用户登录才能执行action中的方法,并给出执行那一个方法,否则提示无权限操作.


1.首先定义一个action.[message作为消息提示]

public class HelloWorldAction {
	//成员变量[字段]
	private String message;
	
	//属性 存取data
	public String getMessage(){
		return message;
	}
	public String execute() throws Exception{
		message="execute";
		return "success";
	}
	
	public String add(){
		message="add";
		return "success";
	}
}

2.模拟用户登录以及注销.

-模拟用户登录,将用户存入session保存   -userlogin.jsp
<%
	request.getSession().setAttribute("user", "init");
%>

用户已登录
</pre><pre class="html" name="code"> 
<%
	request.getSession().removeAttribute("user");
%>
用户已注销

-以及消息提示view - message.jsp

 <html>
    	${message}
    
 </html>

3.定义一个拦截器

public class PermissionInterceptor implements Interceptor {

	@Override
	public void destroy() {	}

	@Override
	public void init() {	}

	@Override
	public String intercept(ActionInvocation invocation) throws Exception {
		//获取用户登录后保存在session中的user
		Object user = ActionContext.getContext().getSession().get("user");
		if(user!=null)
			//放行
			invocation.invoke();
		ActionContext.getContext().put("message", "您没有权限执行该操作");
		return "success";
	}

}


4.struts.xml配置

<struts>
	<!--修改struts的默认请求后缀  -->
	<constant name="struts.action.extension" value="do,action"/>
	<!-- 禁止动态方法调用 -->
	<constant name="struts.enable.DynamicMethodInvocation" value="false"></constant>
	
	<package name="base" extends="struts-default">
		<!-- 全视图 -->
		<global-results>
			<result name="success">/WEB-INF/page/message.jsp</result>
		</global-results>
	</package>
	
	<package name="it" namespace="/control" extends="base">
		
		<!-- 拦截器链 -->
		<interceptors>
			<interceptor name="permission" class="cn.it.interceptor.PermissionInterceptor"/>
			<!-- 拦截器栈 -->
			<interceptor-stack name="permissionStack">
				<!-- 系统默认的放前面 -->
				<interceptor-ref name="defaultStack"/>
				<interceptor-ref name="permission"/>
			</interceptor-stack>
		</interceptors>
		<!-- 包内所有默认拦截器,当某个action显视的定义拦截器后,默认的失效 -->
		<default-interceptor-ref name="permissionStack"/>
		
		
		<!--权限测试  -->
		<action name="permiss_*" class="cn.it.action.HelloWorldAction" method="{1}"> 
			<!-- 调用权限拦截器 -->
			<interceptor-ref name="permissionStack"/>
		</action>
		
	</package>
	
</struts>



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值