`
endual
  • 浏览: 3567376 次
  • 性别: 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的,所以自学很重要。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

分享到:
评论

相关推荐

    Struts2AppStruts2AppStruts2App

    2. **拦截器(Interceptor)**:Struts2的拦截器机制使得在Action执行前后可以插入自定义的行为,如日志记录、权限检查等,增强了框架的灵活性和可扩展性。 3. **结果类型(Result)**:Action执行完成后,会返回一...

    struts2的总结,适合初学者

    1Mvc与servlet 1.1Servlet的优点 1、是mvc的基础,其他的框架比如struts1,struts2,...4、struts2的拦截器为mvc框架注入了全新的概念。 4Struts2入门 4.1新建一个工程为struts2 4.2修改工程的编码为utf-8 4.3导入

    WebWork深入浅出.rar

    2. 拦截器(Interceptor):WebWork的拦截器机制类似于AOP(面向切面编程),允许在动作执行前后插入自定义逻辑。拦截器可以用于事务管理、性能监控、权限验证等多种用途,提高了代码的可复用性。 3. 请求映射...

    struts2.3.16

    Struts 2 内置了许多拦截器,如 `params` (处理请求参数)、`validation` (验证) 和 `exception` (异常处理)。 5. **结果类型(Result Type)**: - 结果类型决定了Action执行后的跳转方式,如转发、重定向、流等。...

    Filter-四个有用的Java过滤器

    `setHeader("Cache-Control", "no-cache")`禁止浏览器缓存,`setHeader("Pragma", "no-cache")`进一步强调不缓存,`setDateHeader("Expires", -1)`将过期时间设置为过去,使得浏览器认为页面已过期。 2. **检测用户...

    java 常用过滤器

    这些过滤器都是基于Servlet规范中的Filter接口实现的,它们通过在web.xml或Java配置中声明并配置,可以实现全局性的拦截和处理。使用过滤器不仅可以提高代码的可复用性,还能降低业务逻辑与视图层的耦合,增强应用...

    三歪教你学SpringMVC.docx

    SpringMVC支持自定义拦截器,用于在处理请求前后执行特定操作。 **6.2 统一异常处理** 可以通过定义全局异常处理器来处理未捕获的异常。 #### 七、总结 SpringMVC是一个非常强大且灵活的Web框架,不仅简化了开发...

    strtuts2、房屋出租系统

    Interceptor是拦截器,可以理解为在Action执行前后插入的逻辑处理,用于实现通用功能,如日志记录、权限验证等。配置文件,通常为struts.xml,定义了Action的映射、结果类型和拦截器链,是整个框架的蓝图。 在...

    vue大型电商项目尚品汇(前台篇)day05.doc

    解决方法是,使用 uuid,封装请求拦截器,然后将 uuid 传递给服务器。 5. 获取 UUID: 获取 UUID 需要创建一个 utils 文件夹,思考的是怎么让我们每次点进来都是得到的那一个临时身份,不会再变,可以把我们获取到...

    Redis+lua+AOP实现简单的限流

    例如,我们可以编写一个Lua脚本,接收当前时间戳和限流阈值作为参数,计算过去一段时间内的请求数量。如果超过阈值,则返回错误,否则更新计数并返回成功。这样,整个限流逻辑都在Redis服务器内部完成,提高了效率和...

    solid state laser engineering

    固态激光器的性能参数是评价其技术水平的关键指标,主要包括但不限于以下几点: - **输出功率**:激光器能够达到的最大输出功率是衡量其性能的重要标准之一。 - **光束质量**:通常用M²因子表示,反映了激光束聚焦...

    struts2基础jar包

    4. **拦截器(Interceptor)**:Struts2的拦截器是其强大功能的重要组成部分。它们在Action调用前后执行,可以实现日志记录、权限检查、数据校验等通用功能。比如,`ValidationInterceptor`用于字段验证,`...

    Struts框架的原理的实现

    Struts框架通过一系列的拦截器(Interceptor)来增强其功能,比如异常处理、数据校验、事务管理等。这些拦截器按照预设的顺序执行,为开发者提供了扩展框架功能的途径。 在实际开发中,Struts提供了大量的标签库...

    AisMVC.zip

    我们团队开发web项目一般采用前后端分离,所以后端的的Controller层的功能仅仅只有提供ajax接口,页面集成后的跳转,过滤器和拦截器,所以我就想着自己写一款仿springmvc的mvc框架作为自己和团队以后的开发中小型项目的...

    简单的SSH整合的例子

    Struts2提供了一套灵活的拦截器机制,允许开发者自定义处理流程。在视图层,它通常与JSP结合使用,展示数据。在这个简单的整合例子中,index.jsp可能是项目的首页,用于展示或接收用户输入。 再者,Hibernate作为...

    SSH框架整合

    Struts2通过配置Action和Result来定义请求的处理流程,并且支持拦截器,可以方便地添加日志、权限检查等预处理或后处理逻辑。Struts2与Spring的结合,使得Action可以通过Spring的依赖注入获取服务,同时也能够利用...

    acegi

    - AOP在Acegi中用于实现安全拦截,通过定义安全拦截器,可以在方法调用前、后或异常时执行特定的安全操作,比如权限检查。 5. **迁移至Spring Security** - 随着Spring框架的发展,Spring Security成为Acegi的...

    如何搭建struts

    1. **Struts2核心库**:`struts2-core-2.3.15.jar` 是Struts2的核心库,包含了框架的主要功能,如Action、拦截器、结果类型等。版本号2.3.15表明这是一个较旧但稳定的版本。 2. **XWork框架**:`xwork-core-2.3.15....

    struts1.2的jar包及源码

    5. **拦截器(Interceptor)**:拦截器是Struts1.2增强功能的重要部分,它们允许在Action执行前后插入额外的逻辑,如日志、权限检查等。 6. **标签库(Taglib)**:Struts1.2提供了丰富的JSP标签,如`s:form`、`s:...

    谷歌浏览器+插件(包能用)

    Flash Player是过去广泛用于在线视频、游戏和交互式内容的插件,但随着HTML5的发展,其使用已逐渐减少,且谷歌浏览器现在默认不支持Flash。 "ChromePortable.exe" 是便携版谷歌浏览器的执行文件,这意味着用户无需...

Global site tag (gtag.js) - Google Analytics