JSP - Filter引起的一个奇怪错误 - 重复jsp内容
2014-04-08 14:20
225 查看
今天在Tomcat启动项目后,发现页面全乱套了。。好多东西都成了双份。
如下截图:
这就是一个简单的页面,页面有一个table,结果显示的时候成了两个table,一开始以为是Jsp页面的问题,通过查看Chrome的Network以及输出日志,没有发现任何问题。找不到任何问题,写了上面这个及其简单的例子后,发现还是重复,显然不是页面的问题了。
在后来想到可能是Filter的问题,因为直接访问jsp的时候也只有Filter(或servlet)可能会拦截jsp页面,因为项目中有一个过滤器来校验用户授权,所以可能是这个Filter的问题。
打开Filter后,看如下(部分)代码:
这里很明显会出现2次的doFilter,第一次执行过doFilter后response已经包含了jsp的内容,等再次执行doFilter时会再次输出一次jsp内容,最后会导致内容重复出现。多次重复执行doFilter会导致respon多次重复操作。
找到问题根源后,修改错误代码,改为一次doFilter后问题解决。
如下截图:
这就是一个简单的页面,页面有一个table,结果显示的时候成了两个table,一开始以为是Jsp页面的问题,通过查看Chrome的Network以及输出日志,没有发现任何问题。找不到任何问题,写了上面这个及其简单的例子后,发现还是重复,显然不是页面的问题了。
在后来想到可能是Filter的问题,因为直接访问jsp的时候也只有Filter(或servlet)可能会拦截jsp页面,因为项目中有一个过滤器来校验用户授权,所以可能是这个Filter的问题。
打开Filter后,看如下(部分)代码:
//TODO 还有一些特殊情况 chain.doFilter(request, response); //跳过校验 if(skip){ chain.doFilter(request, response); } else if (session.getAttribute("USER") != null) {
这里很明显会出现2次的doFilter,第一次执行过doFilter后response已经包含了jsp的内容,等再次执行doFilter时会再次输出一次jsp内容,最后会导致内容重复出现。多次重复执行doFilter会导致respon多次重复操作。
找到问题根源后,修改错误代码,改为一次doFilter后问题解决。
相关文章推荐
- JSP - Filter引起的一个奇怪错误 - 重复jsp内容
- [备忘] 关于Ubuntu包管理器的一个奇怪的错误的解决方案
- 一个数组下标错误引起的字符串错误
- 一个解决下拉框内容重复的JS
- 初学jsp,一个低级错误
- 一个超低级的错误引起的大问题
- php simple_html_dom 一个iconv错误引起解析中断的问题,貌似内存溢出
- 一个由于数据库并发引起的错误,开发环境里一切都正常、运行环境里不稳定、发生莫名奇妙的错误
- 工程导入eclipse后,修改编译级别,仍然报一个奇怪的错误。
- 一个偶然错误引起对gcc和g++的认识
- Hibernate和spring结合的OpenSessionInViewFilter引起的错误解决
- 一个公共的common.jsp,使用Bootstrap所需的引入内容
- 记一个mvn奇怪错误: Archive for required library: 'D:/mvn/repos/junit/junit/3.8.1/junit-3.8.1.jar' in project 'xxx' cannot be read or is not a valid ZIP file
- nginx proxy_next_upstream导致的一个重复提交错误
- 一个ClassLoader引起的JNI链接错误
- DELPHI 调用webservice一个安全问题引起的内存地址错误
- MySQL 的一个奇怪错误
- 用AJAX刷新一个DIV中的jsp内容
- 一个因xdata声明引起的隐含错误
- Yes!~ 我又写了一次树的建立及中序递归遍历。学习是一个不断重复的过程。温故而知新呀!~还是我自己调试出来的,找出错误的感觉真好!~