拦截器 参数不过去 的解决方法

拦截器 参数不过去

博客分类:

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

我很搞不清楚拦截器和校验器的区别呵呵,都是在xml文件中,当初学的时候,可能是基础不扎实,可能是没有参与过实际的开发。杭州的经理们求  实习 呵呵。

好了,下面开始我的问题吧。

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

昨天晚上写拦截器,居然是无法找到action或者是result,我想这一定是路径有问题,但是看了很久就是没发现问题,可能是我的眼睛模糊了,这该死的眼镜店。

创建拦截器,我们就简单的去实现下就可以了,然后再讲拦截中重点的内容和注意的细节吧。

问题简述:jsp页面有表单有个name,传递到action中,首先被拦截器拦截掉,看看是不是应该****的词,如果是的话,就返回到jsp页面重新输入,如果不是的话,那么就传递到action中,然后打印出来,然后跳转到成功页面中去。

1.创建Action类,

Java代码  

  1. package endual.iteye.action;
  2. import com.opensymphony.xwork2.ActionSupport;
  3. public class TestAction extends ActionSupport{
  4. private static final long serialVersionUID = 1L;
  5. private String name ;
  6. @Override
  7. public String execute() throws Exception {
  8. System.out.println("我是action" + name);
  9. return super.execute();
  10. }
  11. public String getName() {
  12. return name;
  13. }
  14. public void setName(String name) {
  15. this.name = name;
  16. }
  17. } //

2.jsp页面

<%@ page language="java" import="java.util.*" pageEncoding="GB18030"%>

Html代码  

  1. <%
  2. String path = request.getContextPath();
  3. String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
  4. %>
  5. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
  6. <html>
  7. <head>
  8. <base href="<%=basePath%>">
  9. <title>My JSP ‘test1.jsp‘ starting page</title>
  10. <meta http-equiv="pragma" content="no-cache">
  11. <meta http-equiv="cache-control" content="no-cache">
  12. <meta http-equiv="expires" content="0">
  13. <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
  14. <meta http-equiv="description" content="This is my page">
  15. <!--
  16. <link rel="stylesheet" type="text/css" href="styles.css">
  17. -->
  18. </head>
  19. <body>
  20. <form action="test.action" method="post">
  21. <input type="text" name="name" value="chenwei" />
  22. <input type="submit" value="submit"/>
  23. </form>
  24. </body>
  25. </html>

3.struts.xml的配置

Xml代码  

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE struts PUBLIC
  3. "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
  4. "http://struts.apache.org/dtds/struts-2.0.dtd">
  5. <struts>
  6. <constant name="struts.enable.DynamicMethodInvocation" value="true" />
  7. <constant name="struts.devMode" value="false" />
  8. <constant name="struts.custom.i18n.resources" value="message"></constant>
  9. <package name="default" extends="struts-default" >
  10. <interceptors>
  11. <interceptor name="testInterceptor" class="endual.iteye.interceptors.TestInterceptor"/>
  12. </interceptors>
  13. <action name="test" class="endual.iteye.action.TestAction">
  14. <result name="success">page1.jsp</result>
  15. <interceptor-ref name="testInterceptor"/>
  16. </action>
  17. </package>
  18. </struts>

4.拦截器的实现

Java代码  

  1. package endual.iteye.interceptors;
  2. import java.util.Map;
  3. import javax.servlet.ServletContext;
  4. import javax.servlet.http.HttpServletRequest;
  5. import org.apache.struts2.ServletActionContext;
  6. import org.apache.struts2.interceptor.RequestAware;
  7. import org.apache.struts2.interceptor.ServletRequestAware;
  8. import org.apache.struts2.interceptor.ServletResponseAware;
  9. import com.opensymphony.xwork2.ActionInvocation;
  10. import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
  11. public class TestInterceptor extends AbstractInterceptor{
  12. @Override
  13. public String intercept(ActionInvocation invo) throws Exception {
  14. HttpServletRequest req = ServletActionContext.getRequest();
  15. String username = req.getParameter("name") ;
  16. System.out.println(username);
  17. if (username.equals("xxxxx")) {
  18. return "login"; //执行返回给struts.xml,result接受到为longin的那个跳转
  19. } else {
  20. // 用户已经登陆,放行~
  21. return invo.invoke();
  22. }
  23. }
  24. }

这样就创建好了一个拦截器。

========================================

很遗憾,上面的拦截器,你会发现,如果你传递进来的xxxxx,那么传递到action中的将无法接受到页面输入的name的

,就是null的空对象了。这是我们初学者会遇到的问题。

||

||

||

||

解决的方法是:

框架中,有一个默认的拦截器,这个拦截器据说是要用到拦截器的时候,一定要调用的,而且每次调用都要用到最后的。我们先来看下拦截器实现的的步骤吧。

Java代码  

  1. package endual.iteye.interceptors;
  2. import java.util.Map;
  3. import javax.servlet.ServletContext;
  4. import javax.servlet.http.HttpServletRequest;
  5. import org.apache.struts2.ServletActionContext;
  6. import org.apache.struts2.interceptor.RequestAware;
  7. import org.apache.struts2.interceptor.ServletRequestAware;
  8. import org.apache.struts2.interceptor.ServletResponseAware;
  9. import com.opensymphony.xwork2.ActionInvocation;
  10. import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
  11. public class TestInterceptor extends AbstractInterceptor{
  12. /**
  13. *
  14. * 1.当表单传递数据的时候,拦截器首先拦截到,
  15. * 2.用session request等获取到表单的数据的,然后进行验证
  16. *
  17. *
  18. */
  19. @Override
  20. public String intercept(ActionInvocation invo) throws Exception {
  21. //3.用request接受到表单传递进来的参数
  22. HttpServletRequest req = ServletActionContext.getRequest();
  23. //4.获取参数的值
  24. String username = req.getParameter("name") ;
  25. System.out.println(username);
  26. //业务上的逻辑处理
  27. if (username.equals("chenwei")) { //如果是的,那么
  28. //拦截器到此终止,传递给struts.xml去处理,不经过下面的拦截器或者是action了
  29. return "login"; //执行返回给struts.xml,result接受到为longin的那个跳转
  30. } else {
  31. // 用户已经登陆,放行~
  32. //放行有两种可能的,一种可能是传递给action的,还有一种可能是传递给下一个拦截的
  33. //这样要看struts.xml中拦截器的配置了
  34. return invo.invoke();
  35. }
  36. }

上面的就是拦截器的工作步骤。

当我们实现的自己的拦截器的时候,那么框架本身并没有那么智能的说,我自己实现了拦截器,然后拦截了就可以传递给action

中表单的数据,其实不是这样的,但是框架的设计者经过了精心的设计,设计出了一个默认的拦截器,这个拦截器来实现这个功能的。

<action name="test" class="endual.iteye.action.TestAction">

Xml代码  

  1. <result name="success">page1.jsp</result>
  2. <interceptor-ref name="testInterceptor"/>
  3. <interceptor-ref name="defaultStack"></interceptor-ref>
  4. t;/action>

<interceptor-ref name="defaultStack"></interceptor-ref>

就是这个拦截器。

写法有很多种的,你可以像我这样写,也可以实现一个拦截器栈,然后调用拦截器中就可以了的。相关的实现请百度查资料吧

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

Java代码  

  1. Struts2中自定义拦截器导致Action注入参数丢失
  2. 2009-03-31 13:59
  3. 做一个登录验证的页面,对集成admin的所有package进行保护。
  4. <interceptors>
  5. <interceptor name="adminLoginInterceptor"
  6. class="interceptor.AdminLoginInterceptor" >
  7. <param name="pass0">6B8E49836C0C29251833227E3B0F7FB7F8DC67CE</param>
  8. </interceptor>
  9. </interceptors>
  10. <default-interceptor-ref name="adminLoginInterceptor" />
  11. 然而发现所有带有传递参数的均无法正常使用了,在Action中所有的参数无法被注入。
  12. 最后发现,struts-default中,默认的拦截器引用是defaultstack,这个拦截器包传说是经过精心设计的。。所以会把所有的参数注入!。。。
  13. 因此要更改默认拦截器,需要加上这个defaultstack
  14. <package name="admin" extends="struts-default" >
  15. <interceptors>
  16. <interceptor name="adminLoginInterceptor"
  17. class="interceptor.AdminLoginInterceptor" >
  18. <param name="pass0">6B8E49836C0C29251833227E3B0F7FB7F8DC67CE</param>
  19. </interceptor>
  20. <interceptor-stack name="adminstack">
  21. <interceptor-ref name="adminLoginInterceptor"></interceptor-ref>
  22. <interceptor-ref name="defaultStack"></interceptor-ref>
  23. </interceptor-stack>
  24. </interceptors>
  25. <default-interceptor-ref name="adminstack" />
  26. <global-results>
  27. <result name="login">/admin/login.jsp</result>
  28. </global-results>
  29. </package>
  30. <default-interceptor-ref name="adminstack" />
  31. <global-results>
  32. <result name="login">/admin/login.jsp</result>
  33. </global-results>
  34. </package>
  35. 特别注意红色两行的顺序!先自定义再Default

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

总结的很好很好

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

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

时间: 2024-10-18 15:47:31

拦截器 参数不过去 的解决方法的相关文章

struts2拦截器interceptor的三种配置方法

struts2拦截器interceptor的三种配置方法方法1. 普通配置法 <struts>     <package name="struts2" extends="struts-default">         <interceptors>             <interceptor name="myInterceptor" class="edu.hust.interceptor.

SpringMVC拦截器中通过反射得到Controller方法注解时ClassCastException解决方案

错误应用场 在Controller中,我们自定义了一个@Auth注解来实现权限控制功能,如: @Auth(verifyLogin=false,verifyURL=false) @RequestMapping("/login") public ModelAndView login(HttpServletRequest request,HttpServletResponse response) throws Exception{ Map<String,Object> conte

使用AOP拦截器获取一次请求流经方法的调用次数和调用耗时

引语 作为工程师,不能仅仅满足于实现了现有的功能逻辑,还必须深入认识系统.一次请求,流经了哪些方法,调用了多少次DB操作,多少次API操作,多少次IO操作,多少CPU操作,各耗时多少 ? 开发者必须知道这些运行时数据,才能对系统的运行有更深入的理解,更好滴提升系统的性能和稳定性. 完成一次订单导出任务,实际上是一个比较复杂的过程:需要访问ES 来查询订单,调用 API 及访问 Hbase 获取订单详情数据,写入和上传报表文件,更新数据库,上报日志数据等:在大流量导出的情形下,采用批量并发策略,多

SpringMvc参数绑定出现乱码解决方法

在SpringMvc参数绑定过程中出现乱码的解决方法 1.post参数乱码的解决方法 在web.xml中添加过滤器 <!-- 过滤器 处理post乱码 --> <filter> <filter-name>CharacterEncodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class

[转]asp.net URL中包含中文参数造成乱码的解决方法

本文转自:http://www.jb51.net/article/22437.htm 问题: 前段时间,在系统中做了一个类似于友情链接的功能块,一直运行良好,直到有一天加了类似于以下的链接地址:http://www.****.com/user.aspx?id=水天,就出现大问题了: 1.从IE地址栏中直接输入这个地址,访问没错: 2.做一个静态页,其中包括这个超链接,点击访问也没错: 3.就是把这个链接添加到这个功能块中,点击访问那边接收到的是乱码. 一开始,被这个问题也搞得头大,在google

IIS服务管理器无法启动网站的解决方法

如图: 启动网站时提示无法启动网站,由于windows Activation Services或者w3svc均未启动.解决方法: 找到World Wide Web Publishing Service服务项,没有启动,右键点击启动. 原文地址:http://bbs.delit.cn/thread-742-1-1.html 转载请注明出处: 撰写人:度量科技http://www.delit.cn

win10下, TakeColor取色器错位 指针偏移问题 解决方法

当win10的屏幕缩放比例不是100%时,屏幕取色器ColorPix指针会发生偏移 解决: 1.右击 —> 属性 —> 兼容性 2.勾选"高DPI缩放替代" 原文地址:https://www.cnblogs.com/FengZeng666/p/12539762.html

request.getParameter(“参数名”) 中文乱码解决方法

今天浏览项目时候,遇到一个问题,页面用${requestScope.参数名 }获取的值是乱码,然后搜了一下,最后说是编码的问题,附上查找的结果: 在Java 开发中,如果框架搭建的不完善或者初学者在学习过程中,出现中文乱码是经常的事儿(哈.谁让发明java语言的不是中国人呢) 今天跟大家分享几个解决java Web开发中,request.getParameter()获取URL中文参数乱码的解决办法 解决问题,先要研究问题,URL传中文参数为什么会出现乱码? 原因:Http请求传输时将url以IS

关于RDLC子报表添加参数 错误“本地报表处理期间出错 。值不能为空。 参数名:value” 错误解决方法

由于对RDLC报表不够熟悉,在出现这个错误时,也是找了一阵才找到解决方案1.首先在网上找了一堆方法后  这句话提醒了我  自定义的名称必须和子报表参数同名 2.然后我仔细比对了一下我的报表和子报表 下图为父报表的子报表参数(此处没有问题) 3.然后我在回到子报表  检查子报表中是否有同名的参数和数据集,并设置参数可为空 (注意: 查询的SQL 必须也要有这个字段) 4. 最后一点很重要,属性, 在筛选器中填写表达式  注意 表达式和值不一样 这样基本就OK了!