天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

jsp 對request.getSession(false)的理解(附程序員常疏忽的一個漏洞)

【前面的話】
在網上經常看到有人對request.getSession(false)提出疑問,我第一次也很迷惑,看了一下J2EE1.3 API,看一下官網是怎么解釋的。
【官方解釋】
getSession
public HttpSession getSession(boolean create)
Returns the current HttpSession associated with this request or, if if there is no current session and create is true, returns a new session.
If create is false and the request has no valid HttpSession, this method returns null.
To make sure the session is properly maintained, you must call this method before the response is committed. If the container is using cookies to maintain session integrity and is asked to create a new session when the response is committed, an IllegalStateException is thrown.
Parameters: true - to create a new session for this request if necessary; false to return null if there's no current session
Returns: the HttpSession associated with this request or null if create is false and the request has no valid session
譯:
getSession(boolean create)意思是返回當前reqeust中的HttpSession ,如果當前reqeust中的HttpSession 為null,當create為true,就創建一個新的Session,否則返回null;
簡而言之:
HttpServletRequest.getSession(ture) 等同于 HttpServletRequest.getSession()
HttpServletRequest.getSession(false) 等同于 如果當前Session沒有就為null;
【問題和bug】:
我周圍很多同事是這樣寫的;
復制代碼 代碼如下:
HttpSession session = request.getSession(); // a new session created if no session exists, 哈哈!完蛋啦!如果session不存在的話你又創建了一個!
String user_name = session.getAttribute("user_name");

需要注意的地方是request.getSession() 等同于 request.getSession(true),除非我們確認session一定存在或者sesson不存在時明確有創建session的需要,否則盡量使用request.getSession(false)。在使用request.getSession()函數,通常在action中檢查是否有某個變量/標記存放在session中。這個場景中可能出現沒有session存在的情況,正常的判斷應該是這樣:
復制代碼 代碼如下:
HttpSession session = request.getSession(false);
if (session != null) {
String user_name = session.getAttribute("user_name");
}

【投機取巧】:

如果項目中用到了Spring(其實只要是Java的稍大的項目,Spring是一個很好的選擇),對session的操作就方便多了。如果需要在Session中取值,可以用WebUtils工具(org.springframework.web.util.WebUtils)的getSessionAttribute(HttpServletRequest request, String name)方法,看看高手寫的源碼吧:哈哈。。
復制代碼 代碼如下:
/**
* Check the given request for a session attribute of the given name.
* Returns null if there is no session or if the session has no such attribute.
* Does not create a new session if none has existed before!
* @param request current HTTP request
* @param name the name of the session attribute
* @return the value of the session attribute, or <code>null</code> if not found
*/
public static Object getSessionAttribute(HttpServletRequest request, String name) {
Assert.notNull(request, "Request must not be null");
HttpSession session = request.getSession(false);
return (session != null ? session.getAttribute(name) : null);
}

注:Assert是Spring工具包中的一個工具,用來判斷一些驗證操作,本例中用來判斷reqeust是否為空,若為空就拋異常。
上面的代碼又可以簡潔一下啦,看吧:
復制代碼 代碼如下:
HttpSession session = request.getSession(false);
String user_name = WebUtils.getSessionAttribute(reqeust, "user_name");

來源:http://blog.csdn.NET/xxd851116

jsp技術jsp 對request.getSession(false)的理解(附程序員常疏忽的一個漏洞),轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 久久99国产精品无码AV | 久久亚洲视频 | 欧洲兽交另类AVXXX | 99re久久热在线播放8 | 一个人高清在线观看日本免费 | 国产一区二区三区影院 | 国产成人精品区在线观看 | 久久这里只有是精品23 | 波多野结衣的AV一区二区三区 | 青青青草免费 | 亚洲精品乱码久久久久久v 亚洲精品乱码电影在线观看 | 久久精品视频15人人爱在线直播 | 国产精品无码中文在线AV | 亚洲综合小说久久另类区 | 国产精彩视频在线 | 欧美乱妇15p图 | 无人影院在线播放视频 | 少妇无码太爽了视频在线播放 | 日产日韩亚洲欧美综合搜索 | 久久视频精品38线视频在线观看 | 91精品一区二区三区在线观看 | 精品手机在线1卡二卡3卡四卡 | 老妇高潮潮喷到猛进猛出 | 中文字幕高清在线观看 | 亚洲精品国产一区二区贰佰信息网 | 青娱乐视觉盛宴国产视频 | 野草在线视频完整视频 | 狠狠射首页 | 国产色婷婷亚洲99麻豆 | 麻花传媒MD0044视频 | 97成人碰碰在线人妻少妇 | 免费看午夜高清性色生活片 | 95国产精品人妻无码久 | 久久人人玩人妻潮喷内射人人 | 3D动漫网站HOXXXxes | 色婷婷AV国产精品欧美毛片 | 无码乱人伦一区二区亚洲一 | 国产在线精品一区二区网站免费 | 新新电影理论中文字幕 | 色欲人妻无码AV专区 | 欧美黄色一级 |