麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JSP > 正文

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

2024-09-05 00:21:13
字體:
來源:轉載
供稿:網友
在網上經常看到有人對request.getSession(false)提出疑問,我第一次也很迷惑,看了一下J2EE1.3 API,看一下官網是怎么解釋的。

【前面的話】
在網上經常看到有人對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");


來源:
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 精品一区二区三区免费毛片爱 | 91精品国产综合久久久欧美 | 香蕉国产在线视频 | 久久国产精品久久精品国产演员表 | 永久在线观看电影 | 亚洲第九十九页 | 久久久青 | 成人福利电影在线观看 | 欧美一区黄色 | 大号bbwassbigav头交 | 国产亚洲精品久久午夜玫瑰园 | 成年免费观看视频 | 国产成人在线观看免费网站 | 欧美一级美国一级 | 娇妻被各种姿势c到高潮小说 | 亚洲成人激情av | 日本大片在线播放 | 99精品国产小情侣高潮露脸在线 | 九九热精品视频在线 | 国产91久久久久久 | 斗罗破苍穹在线观看免费完整观看 | 久久亚洲精品久久国产一区二区 | 在线观看免费av网 | 日韩精品久久久久久久九岛 | 欧美一区二区三区免费不卡 | 午夜生活理论片 | 成人黄视频在线观看 | 精品久久久久久久久久久久久久久久久久久 | 日韩精品中文字幕一区二区三区 | 久草导航 | 欧美a视频| 制服丝袜日日夜夜 | 日韩视频精品一区 | 欧美在线观看视频一区 | 色妇视频| 特级无码毛片免费视频尤物 | 一级做a爱片久久毛片a高清 | 成人在线视频精品 | 欧美精品久久天天躁 | 亚洲国产一区二区三区 | 欧美成人精品不卡视频在线观看 |