JSP - Filter引起的一个奇怪错误 - 重复jsp内容

今天在Tomcat启动项目后,发现页面全乱套了。。好多东西都成了双份。


如下截图:


这就是一个简单的页面,页面有一个table,结果显示的时候成了两个table,一开始以为是Jsp页面的问题,通过查看Chrome的Network以及输出日志,没有发现任何问题。找不到任何问题,写了上面这个及其简单的例子后,发现还是重复,显然不是页面的问题了。


在后来想到可能是Filter的问题,因为直接访问jsp的时候也只有Filter(或servlet)可能会拦截jsp页面,因为项目中有一个过滤器来校验用户授权,所以可能是这个Filter的问题。


打开Filter后,看如下(部分)代码:

  1. //TODO 还有一些特殊情况 
  2. chain.doFilter(request, response); 
  3. //跳过校验 
  4. if(skip){ 
  5.     chain.doFilter(request, response); 
  6. else if (session.getAttribute("USER") != null) { 
//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后问题解决。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值