还是同样的问题,拦截器在以前学的时候,学的不怎么领会,所以学过忘记了。
我很搞不清楚拦截器和校验器的区别呵呵,都是在xml文件中,当初学的时候,可能是基础不扎实,可能是没有参与过实际的开发。杭州的经理们求 实习 呵呵。
好了,下面开始我的问题吧。
----------------------------------------
昨天晚上写拦截器,居然是无法找到action或者是result,我想这一定是路径有问题,但是看了很久就是没发现问题,可能是我的眼睛模糊了,这该死的眼镜店。
创建拦截器,我们就简单的去实现下就可以了,然后再讲拦截中重点的内容和注意的细节吧。
问题简述:jsp页面有表单有个name,传递到action中,首先被拦截器拦截掉,看看是不是应该****的词,如果是的话,就返回到jsp页面重新输入,如果不是的话,那么就传递到action中,然后打印出来,然后跳转到成功页面中去。
1.创建Action类,
- package endual.iteye.action;
- import com.opensymphony.xwork2.ActionSupport;
- public class TestAction extends ActionSupport{
- private static final long serialVersionUID = 1L;
- private String name ;
- @Override
- public String execute() throws Exception {
- System.out.println("我是action" + name);
- return super.execute();
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- } //
2.jsp页面
<%@ page language="java" import="java.util.*" pageEncoding="GB18030"%>
- <%
- String path = request.getContextPath();
- String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
- %>
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
- <html>
- <head>
- <base href="<%=basePath%>">
- <title>My JSP 'test1.jsp' starting page</title>
- <meta http-equiv="pragma" content="no-cache">
- <meta http-equiv="cache-control" content="no-cache">
- <meta http-equiv="expires" content="0">
- <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
- <meta http-equiv="description" content="This is my page">
- <!--
- <link rel="stylesheet" type="text/css" href="styles.css">
- -->
- </head>
- <body>
- <form action="test.action" method="post">
- <input type="text" name="name" value="chenwei" />
- <input type="submit" value="submit"/>
- </form>
- </body>
- </html>
3.struts.xml的配置
- <?xml version="1.0" encoding="UTF-8" ?>
- <!DOCTYPE struts PUBLIC
- "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
- "http://struts.apache.org/dtds/struts-2.0.dtd">
- <struts>
- <constant name="struts.enable.DynamicMethodInvocation" value="true" />
- <constant name="struts.devMode" value="false" />
- <constant name="struts.custom.i18n.resources" value="message"></constant>
- <package name="default" extends="struts-default" >
- <interceptors>
- <interceptor name="testInterceptor" class="endual.iteye.interceptors.TestInterceptor"/>
- </interceptors>
- <action name="test" class="endual.iteye.action.TestAction">
- <result name="success">page1.jsp</result>
- <interceptor-ref name="testInterceptor"/>
- </action>
- </package>
- </struts>
4.拦截器的实现
- package endual.iteye.interceptors;
- import java.util.Map;
- import javax.servlet.ServletContext;
- import javax.servlet.http.HttpServletRequest;
- import org.apache.struts2.ServletActionContext;
- import org.apache.struts2.interceptor.RequestAware;
- import org.apache.struts2.interceptor.ServletRequestAware;
- import org.apache.struts2.interceptor.ServletResponseAware;
- import com.opensymphony.xwork2.ActionInvocation;
- import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
- public class TestInterceptor extends AbstractInterceptor{
- @Override
- public String intercept(ActionInvocation invo) throws Exception {
- HttpServletRequest req = ServletActionContext.getRequest();
- String username = req.getParameter("name") ;
- System.out.println(username);
- if (username.equals("xxxxx")) {
- return "login"; //执行返回给struts.xml,result接受到为longin的那个跳转
- } else {
- // 用户已经登陆,放行~
- return invo.invoke();
- }
- }
- }
这样就创建好了一个拦截器。
========================================
很遗憾,上面的拦截器,你会发现,如果你传递进来的xxxxx,那么传递到action中的将无法接受到页面输入的name的
,就是null的空对象了。这是我们初学者会遇到的问题。
||
||
||
||
解决的方法是:
框架中,有一个默认的拦截器,这个拦截器据说是要用到拦截器的时候,一定要调用的,而且每次调用都要用到最后的。我们先来看下拦截器实现的的步骤吧。
- package endual.iteye.interceptors;
- import java.util.Map;
- import javax.servlet.ServletContext;
- import javax.servlet.http.HttpServletRequest;
- import org.apache.struts2.ServletActionContext;
- import org.apache.struts2.interceptor.RequestAware;
- import org.apache.struts2.interceptor.ServletRequestAware;
- import org.apache.struts2.interceptor.ServletResponseAware;
- import com.opensymphony.xwork2.ActionInvocation;
- import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
- public class TestInterceptor extends AbstractInterceptor{
- /**
- *
- * 1.当表单传递数据的时候,拦截器首先拦截到,
- * 2.用session request等获取到表单的数据的,然后进行验证
- *
- *
- */
- @Override
- public String intercept(ActionInvocation invo) throws Exception {
- //3.用request接受到表单传递进来的参数
- HttpServletRequest req = ServletActionContext.getRequest();
- //4.获取参数的值
- String username = req.getParameter("name") ;
- System.out.println(username);
- //业务上的逻辑处理
- if (username.equals("chenwei")) { //如果是的,那么
- //拦截器到此终止,传递给struts.xml去处理,不经过下面的拦截器或者是action了
- return "login"; //执行返回给struts.xml,result接受到为longin的那个跳转
- } else {
- // 用户已经登陆,放行~
- //放行有两种可能的,一种可能是传递给action的,还有一种可能是传递给下一个拦截的
- //这样要看struts.xml中拦截器的配置了
- return invo.invoke();
- }
- }
上面的就是拦截器的工作步骤。
当我们实现的自己的拦截器的时候,那么框架本身并没有那么智能的说,我自己实现了拦截器,然后拦截了就可以传递给action
中表单的数据,其实不是这样的,但是框架的设计者经过了精心的设计,设计出了一个默认的拦截器,这个拦截器来实现这个功能的。
<action name="test" class="endual.iteye.action.TestAction">
- <result name="success">page1.jsp</result>
- <interceptor-ref name="testInterceptor"/>
- <interceptor-ref name="defaultStack"></interceptor-ref>
- t;/action>
<interceptor-ref name="defaultStack"></interceptor-ref>
就是这个拦截器。
写法有很多种的,你可以像我这样写,也可以实现一个拦截器栈,然后调用拦截器中就可以了的。相关的实现请百度查资料吧
---------------
- Struts2中自定义拦截器导致Action注入参数丢失
- 2009-03-31 13:59
- 做一个登录验证的页面,对集成admin的所有package进行保护。
- <interceptors>
- <interceptor name="adminLoginInterceptor"
- class="interceptor.AdminLoginInterceptor" >
- <param name="pass0">6B8E49836C0C29251833227E3B0F7FB7F8DC67CE</param>
- </interceptor>
- </interceptors>
- <default-interceptor-ref name="adminLoginInterceptor" />
- 然而发现所有带有传递参数的均无法正常使用了,在Action中所有的参数无法被注入。
- 最后发现,struts-default中,默认的拦截器引用是defaultstack,这个拦截器包传说是经过精心设计的。。所以会把所有的参数注入!。。。
- 因此要更改默认拦截器,需要加上这个defaultstack
- <package name="admin" extends="struts-default" >
- <interceptors>
- <interceptor name="adminLoginInterceptor"
- class="interceptor.AdminLoginInterceptor" >
- <param name="pass0">6B8E49836C0C29251833227E3B0F7FB7F8DC67CE</param>
- </interceptor>
- <interceptor-stack name="adminstack">
- <interceptor-ref name="adminLoginInterceptor"></interceptor-ref>
- <interceptor-ref name="defaultStack"></interceptor-ref>
- </interceptor-stack>
- </interceptors>
- <default-interceptor-ref name="adminstack" />
- <global-results>
- <result name="login">/admin/login.jsp</result>
- </global-results>
- </package>
- <default-interceptor-ref name="adminstack" />
- <global-results>
- <result name="login">/admin/login.jsp</result>
- </global-results>
- </package>
- 特别注意红色两行的顺序!先自定义再Default
总结的很好很好
-------------------
大家都很忙,所以独立很重要,我们都是搞IT的,所以自学很重要。