|
1. Skriv en handling först paketåtgärder; public class InterceptorAction { public String fun1() { return "ok"; }}
2. Konfigurera åtgärden <package name="base" extends="struts-default"> <global-results> <result name="message">/index.jsp</result> <result name="message">/WEB-INF/page/message.jsp </result> </global-results>< </package> paketnamn="delversi" namnrymd="/test" extends="base"> <interceptors> <interceptor name="permission" class="interceptor.InterceptorDemo"></interceptor> <interceptor-stack name="permissionStack"> <interceptor-ref name="defaultStack"></interceptor-ref> <interceptor-ref name="permission"></interceptor-ref> </interceptor-stack> </interceptors> <action name="interceptor_*" class="action.InterceptorAction" method="{1}"> <interceptor-ref name="permission"></interceptor-ref> <result name="ok">/ddd.jsp</result> </action>
Interceptorstacken är definierad för att kunna använda systemets inbyggda interceptorer
3. Skriv en behörighetsblockerare paketinterceptor; importera com.opensymphony.xwork2.ActionContext; importera com.opensymphony.xwork2.ActionInvocation; importera com.opensymphony.xwork2.interceptor.Interceptor; public class InterceptorDemo implementerar Interceptor { public void destroy() { // TODO Auto-generated method stub } public void init() { // TODO Autogenererad metodstub } publik Strängintercept (ActionInvocation anrop) kastar Undantag { System.out.println("Enter interceptor"); } om (ActionContext.getContext().getSession().get("user") !=null ) { return invocation.invoke(); }else { ActionContext.getContext().put("message", "no permission"); returnera "meddelande"; } }}Loggade in, kom tillbaka OK, och fick tillbaka meddelandet om inte
4. Skriv en jsp och injicera användaren i sessionen <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%><% request.getSession().setAttribute("user","111");%>
Vänligen ange källan för återutgåvahttp://blog.csdn.net/z1104222568/article/details/42218125
|