JSP開發(fā)中在spring mvc項目中實現(xiàn)登錄賬號單瀏覽器登錄
JSP開發(fā)中在spring mvc項目中實現(xiàn)登錄賬號單瀏覽器登錄
在很多web產(chǎn)品中都需要實現(xiàn)在同一時刻,只能允許一個賬號同時只能在一個瀏覽器當中登錄。通俗點講就是當A賬號在
瀏覽器1當中登錄了,此時在瀏覽器2中登錄A賬號。那么在瀏覽器1中的A賬號將會被擠出去,當用戶操作瀏覽器1的頁面,頁面會
跳到登錄頁面,需要重新登錄。那么我們怎么實現(xiàn)這樣的功能呢?下面將給大家進行詳細的介紹:
原理
用戶A使用賬號a在瀏覽器當中登錄,然后用戶B在另外一臺電腦上的瀏覽器登錄賬號a,當用戶B登錄驗證成功時,將會觸
發(fā)登錄監(jiān)聽類,在監(jiān)聽類當中判斷出賬號a已經(jīng)被用戶A登錄,就把用戶A的賬號a 踢出去,此時當用戶A操作頁面,頁面就會跳轉(zhuǎn)到登錄頁面。
代碼實現(xiàn)
在實現(xiàn)過程中,用到LoginListenner監(jiān)聽類、login登錄方法以及在web.xml中配置監(jiān)聽類
LoginListenner
當?shù)卿洺晒?,向session中放入登錄成功的賬號對象loginuser,觸發(fā)LoginListenner中的attributeAdded事件,在這個事件中,
我們判斷存放賬號和session對應關系的map中是否有當前登錄的賬號的session,如果有我們就把該session從map中移除,同時注銷該session,然后把剛登錄的賬號和session放入map。
下面是代碼:
/** * * @ClassName: LoginListenner * @Description: 登錄監(jiān)聽類-處理同一時間只允許賬號,單地點登錄 * @author mr_smile2014 605051929@qq.com * @date 2014年11月12日 下午2:23:41 * */ public class LoginListenner implements HttpSessionAttributeListener { /** * 用于存放賬號和session對應關系的map */ private Map<String, HttpSession> map = new HashMap<String, HttpSession>(); /** * 當向session中放入數(shù)據(jù)觸發(fā) */ public void attributeAdded(HttpSessionBindingEvent event) { String name = event.getName(); if (name.equals("loginuser")) { User user = (User) event.getValue(); if (map.get(user.getUserName()) != null) { HttpSession session = map.get(user.getUserName()); session.removeAttribute(user.getUserName()); session.invalidate(); } map.put(user.getUserName(), event.getSession()); } } /** * 當向session中移除數(shù)據(jù)觸發(fā) */ public void attributeRemoved(HttpSessionBindingEvent event) { String name = event.getName(); if (name.equals("loginuser")) { User user = (User) event.getValue(); map.remove(user.getUserName()); } } public void attributeReplaced(HttpSessionBindingEvent event) { } public Map<String, HttpSession> getMap() { return map; } public void setMap(Map<String, HttpSession> map) { this.map = map; } }
登錄方法
對賬號、密碼、驗證碼進行判斷和驗證,驗證通過后把對應的用戶對象放入到session中,代碼如下:
/** * 登錄 * * @param userName * @param passWord * @param code * 驗證碼 * @param type * 登陸類型(商戶,操作員) * @param model * @return */ @RequestMapping("/login") public String login(String account, String passWord, String code, Model model, HttpServletRequest request) { //登錄驗證并返回登錄成功用戶對象 User user=loginResult(userPhone, passWord, code, request); //把用戶對象放入到session中,將會觸發(fā)LoginListenner中的attributeAdded事件 request.getSession().setAttribute("loginuser", user); }
web.xml配置
把LoginListenner監(jiān)聽類,配置到web.xml文件中,這樣對session的監(jiān)聽才生效。配置如下:
<!--一個用戶只能在一個主機登錄 --> <listener> <listener-class>com.test.listenner.LoginListenner</listener-class> </listener>
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
- JSP使用MVC模式完成刪除和修改功能實例詳解
- JSP使用Servlet作為控制器實現(xiàn)MVC模式實例詳解
- springMVC如何將controller中數(shù)據(jù)傳遞到jsp頁面
- springMVC如何將controller中Model數(shù)據(jù)傳遞到jsp頁面
- SpringMVC 向jsp頁面?zhèn)鬟f數(shù)據(jù)庫讀取到的值方法
- 淺談SpringMVC jsp前臺獲取參數(shù)的方式 EL表達式
- JSP中springmvc配置validator的注意事項
- JavaWeb實現(xiàn)用戶登錄注冊功能實例代碼(基于Servlet+JSP+JavaBean模式)
- jsp 實現(xiàn)的簡易mvc模式示例
相關文章
JSP中內(nèi)建exception對象時出現(xiàn)500錯誤的解決方法
這篇文章主要介紹了JSP中內(nèi)建exception對象時出現(xiàn)500錯誤的解決方法,以一個簡單實例形式分析了exception對象出現(xiàn)500錯誤的解決方法,涉及瀏覽器及error文件的設置技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-11-11response.setContentType()的作用及MIME參數(shù)詳解
response.setContentType(MIME)的作用是使客戶端瀏覽器,區(qū)分不同種類的數(shù)據(jù),并根據(jù)不同的MIME調(diào)用瀏覽器內(nèi)不同的程序嵌入模塊來處理相應的數(shù)據(jù),本文詳細介紹,需要了解的朋友可以參考下2012-12-12Java 創(chuàng)建cookie和刪除cookie
java下創(chuàng)建cookie的代碼,包括了創(chuàng)建跟刪除。2009-04-04jsp servlet javaBean后臺分頁實例代碼解析
這篇文章主要為大家詳細解析了jsp servlet javaBean后臺分頁實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-10-10