码迷,mamicode.com
首页 > Web开发 > 详细

web应用不断创建新的session

时间:2014-09-17 18:38:12      阅读:188      评论:0      收藏:0      [点我收藏+]

标签:des   blog   io   使用   ar   文件   sp   问题   代码   

    今天同事在本地搭建web应用的开发环境后,登陆时一直报空指针异常。经查看日志后发现,是因为在读取session里的属性时,获取到了null值。经过查看代码,没有发现什么异常。有些地方用到了response.redirect()方法,但不至于获取不到session里的值。本文将记录是如何解决此问题的。

    一、开发环境:weblogic、myEclipse。

    二、解决问题思路:

    1、确认不是因为代码的原因造成的,我怀疑是session重新创建的原因。为验证此结论,我在代码里将session id的值打印到控制台。具体的位置有两个地方:一个是在将登陆信息放到session时,一个是在访问session里的登陆信息时。经过查看输出信息发现,俩ID完全不一样,说明session被重新创建了。

    2、session不断重新创建,根据session的原理,可以知道服务器没有从请求头中获得有效jsessionid信息。所以考虑本地禁用了cookie,经确认,本地没有禁用cookie。此路不通。

    3、怀疑session被失效了。创建了一个session的监听类,没有发现session失效的动作。

    4、后来查看weblogic的配置文件,发现有对cookie的路径进行设置:

<weblogic-web-app>
    <session-descriptor>
        <session-param>
            <param-name>CookiePath</param-name>
            <param-name>/cw/</param-name>
        </session-param>
    </session-descriptor>
</weblogic-web-app>

    将路径改为/cw/,因为本地没有此目录,所以cookie文件根本没有正确创建。因此,在将登陆信息放入session后,jsessionid应该要放入cookie中供下次使用,但因为路径找不到,导致cookie文件没有被正确创建,而且,在重定向后,请求同样找不到cookie文件,所以导致没有jsessionid的信息,因此服务器从该请求中找到不到任何session的信息,只能重新创建一个session。因此导致本文开头时说到的问题。


    此问题可以类推到其他的web容器,比如tomcat。

web应用不断创建新的session

标签:des   blog   io   使用   ar   文件   sp   问题   代码   

原文地址:http://blog.csdn.net/ado1986/article/details/39346195

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!