`
endual
  • 浏览: 3507532 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

拦截器 参数不过去

 
阅读更多

 

 

    还是同样的问题,拦截器在以前学的时候,学的不怎么领会,所以学过忘记了。

    我很搞不清楚拦截器和校验器的区别呵呵,都是在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>
           </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

 http://hi.baidu.com/liheyuan87/blog/item/6308b8cb17c7fdf552664f92.html

总结的很好很好

-------------------

 

大家都很忙,所以独立很重要,我们都是搞IT的,所以自学很重要。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics