struts2 登录拦截

struts.xml


<struts>
	<package name="myPackage" extends="json-default" namespace="/tools">
		<interceptors>
			<!-- 权限控制拦截器 -->
			<interceptor name="authority"
				class="com.report.common.action.interceptor.MyInterceptor" />
			<interceptor-stack name="mydefault">
				<interceptor-ref name="defaultStack" />
				<interceptor-ref name="authority" />
			</interceptor-stack>
		</interceptors>
		<!-- 定义默认的拦截器 -->
		<default-interceptor-ref name="mydefault" />
		<global-results>
			<result name="login">/page/common/login.jsp</result>
		</global-results>

		<action name="login" class="LoginAction" method="login">
			<result name="success">/page/reportManager.jsp</result>
		</action>
		<action name="search" class="ReportManagerAction" method="search">
			<result name="success">/page/reportManager.jsp</result>
		</action>
		<action name="del" class="ReportManagerAction" method="del">
			<result name="success">/page/reportManager.jsp</result>
		</action>

	</package>
</struts>

MyInterceptor.java

public class MyInterceptor extends AbstractInterceptor {

	private static final long serialVersionUID = 9189629336555922574L;

	@Override
	public String intercept(ActionInvocation invocation) throws Exception {
		Map session = invocation.getInvocationContext().getSession();
		String actionName = invocation.getProxy().getActionName(); 
		if("login".equals(actionName)){
			return invocation.invoke();
		}
		String userId = (String)session.get("userId");
		if(userId == null || userId.equals("")){
			ServletActionContext.getRequest().setAttribute("nologin", "您尚未登录,请登录后再进行其他操作!");
			return "login";
		}else{
			return invocation.invoke();
		}
	}
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值