這個(gè)問題是之前在做登錄注冊(cè)模塊時(shí)遇到的需求,如何用戶直接訪問登錄頁面,可以控制直接跳到首頁,但是如果是用戶沒有登錄直接訪問了購物車等需要經(jīng)過身份認(rèn)證的頁面,或者是因?yàn)閟ession超時(shí),用戶需要重新登錄,那么這時(shí)跳回之前的頁面就是提升用戶體驗(yàn)的事情。實(shí)現(xiàn)此功能比較好的方法是用ajax的方式登陸,這樣直接在當(dāng)前頁面彈窗讓用戶登錄既可,二是把用戶未登錄前的url存在session中,login成功之后先檢查session中是否存在這樣的一個(gè)url。下面通過一段代碼給大家分享下:
項(xiàng)目中集成了shiro,里面就有這么個(gè)功能,防止WebUtils工具類里面。
廢話了這么多,其實(shí)網(wǎng)上也有人寫過這么一篇關(guān)于這個(gè)功能實(shí)現(xiàn)的的博文,這個(gè)大神寫的shiro教程也是蠻值得一看的,只不過我在使用
SavedRequest savedRequest = WebUtils.getSavedRequest(request);的時(shí)候,savedRequest 對(duì)象一直為空,囧了一段時(shí)間,后面再群里遇到高人指點(diǎn),發(fā)現(xiàn)是自己的配置文件沒寫好,即shiroFilter中的filterChainDefinitions,所需要攔截的url沒有寫完全,像下面這段配置
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
<!-- Shiro的Web過濾器 --> <bean id= "shiroFilter" class = "org.apache.shiro.spring.web.ShiroFilterFactoryBean" > <property name= "securityManager" ref= "securityManager" /> <property name= "loginUrl" value= "/cooka-user-web/login" /> <property name= "unauthorizedUrl" value= "/unauthorized " /> <property name= "filters" > <util:map> <entry key= "authc" > <bean class = "org.apache.shiro.web.filter.authc.PassThruAuthenticationFilter" /> </entry> </util:map> </property> <property name= "filterChainDefinitions" > <value> # 無需認(rèn)證便可以訪問的的文件放在前面 /js/* = anon /css/* = anon /img/* = anon /images/* = anon /user-web/login = anon /logout = logout /user-web/* = authc /backend-web/* = authc </value> </property> </bean> |
只有/user-web/* (除去login,這里url的匹配使用短路機(jī)制,即最先匹配原則)和/backend-web/ 后面的url,才會(huì)被允許存入到session中,這樣,當(dāng)用戶沒有登陸就去訪問包含以上兩種鏈接前綴的時(shí)候,登陸成功后就會(huì)跳轉(zhuǎn)到之前的界面了。
以上內(nèi)容就是本文全部介紹,希望能夠幫助到大家