首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

哪位高手在创建session(1)-不恰当的request.getSession()

2012-10-26 
谁在创建session(1)-不恰当的request.getSession()在HttpServlet中,HttpSession对象通常在request.getSess

谁在创建session(1)-不恰当的request.getSession()
在HttpServlet中,HttpSession对象通常在request.getSession(true)方法调用时才创建。 HttpSession的使用是有代价的,需要占用服务器资源,本着能不浪费就不浪费的原则,我希望系统中的session都在掌握之中,在需要创建时由我们的代码明确创建。但是最近在开发中发现,新的session对象经常在意料之外出现,究竟是谁在创建session呢?

    最常见的地方是错误的使用request.getSession()函数,通常在action中检查是否有某个变量/标记存放在session中。这个场景中可能出现没有session存在的情况,正常的判断应该是这样:

private boolean ifFlagExistInSession(HttpServletRequest request) {    HttpSession session = request.getSession(false);    if (session != null) {        if (session.getAttribute("flagName")  != null) {            return true;        }    }    return false;}


    而下面的写法,则可能会生成一个新的不在我们意图之外的session:
private boolean ifFlagExistInSession(HttpServletRequest request) {    HttpSession session = request.getSession();   // a new session created if no session exists    if (session.getAttribute("flagName")  != null) {        return true;    }    return false;}


    注意request.getSession() 等同于 request.getSession(true),除非我们确认session一定存在或者sesson不存在时明确有创建session的需要,否则请尽量使用request.getSession(false)。

热点排行