SpringBoot怎么實現Session共享?針對這個問題,這篇文章給出了相對應的分析和解答,希望能幫助更多想解決這個問題的朋友找到更加簡單易行的辦法。
一. SpringBoot中實現Session共享
Spring Boot是由Pivotal團隊提供的全新框架,其設計目的是用來簡化新Spring應用的初始搭建以及開發過程。該框架使用了特定的方式來進行配置,從而使開發人員不再需要定義樣板化的配置。通過這種方式,Spring Boot致力于在蓬勃發展的快速應用開發領域(rapid application development)成為領導者。
1. 創建web項目
我們按照之前的經驗,創建一個web程序,并將之改造成Spring Boot項目,具體過程略。
2.添加依賴包
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> <dependency> <groupId>org.springframework.session</groupId> <artifactId>spring-session-data-redis</artifactId> </dependency> <dependency> <groupId>org.springframework.session</groupId> <artifactId>spring-session-core</artifactId> </dependency>
3.創建application.yml文件
server: port: 8080 #配置redis spring: redis: host: 127.0.0.1 port: 6379 #password: 123456 jedis: pool: max-idle: 8 min-idle: 0 max-active: 8 #max-wait: 60000 #timeout: 3000 #超時一定要大于0 session: #設置session存儲類型 store-type: redis
這里可以設置多種session的store-type:
Session:在計算機中,尤其是在網絡應用中,稱為"會話控制"。Session 對象存儲特定用戶會話所需的屬性及配置信息。這樣,當用戶在應用程序的 Web 頁之間跳轉時,存儲在 Session 對象中的變量將不會丟失,而是在整個用戶會話中一直存在下去。
我們這里選擇利用redis來對session進行集中存儲,實現session共享。
4.創建Session配置類
package com.yyg.boot.config; import org.springframework.context.annotation.Configuration; import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession; /** * @Author 一一哥Sun * @Date Created in 2020/4/28 * @Description 開啟Redis Http Session */ @Configuration @EnableRedisHttpSession(maxInactiveIntervalInSeconds = 3600) public class RedisHttpSessionConfiguration { }
在這里添加@EnableRedisHttpSession注解,可以通過maxInactiveIntervalInSeconds屬性設置Session的過期時間。
5.創建一個Controller接口方法
該接口方法當用戶不存在時提示“用戶不存在”,否則會提示“用戶存在”。
package com.yyg.boot.web; import lombok.extern.slf4j.Slf4j; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import javax.servlet.http.Cookie; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpSession; /** * @Author 一一哥Sun * @Date Created in 2020/4/28 * @Description Description */ @Slf4j @RestController public class SessionController { @RequestMapping("/session") public Object springSession(@RequestParam("username") String username, HttpServletRequest request, HttpSession session) { Cookie[] cookies = request.getCookies(); if (cookies != null && cookies.length > 0) { for (Cookie cookie : cookies) { log.warn(cookie.getName() + "=" + cookie.getValue()); } } Object value = session.getAttribute("username"); if (value == null) { log.warn("用戶不存在"); //保存session session.setAttribute("username", "{username: '" + username + "', age: 30}"); } else { log.warn("用戶存在"); } return "username=" + value; } }
6.創建入口類
package com.yyg.boot; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; /** * @Author 一一哥Sun * @Date Created in 2020/4/28 * @Description Description */ @SpringBootApplication public class SpringSessionApplication { public static void main(String[] args){ springapplication.run - 這個網站可出售。 - 最佳的springapplication 來源和相關信息。(SpringSessionApplication.class,args); } }
7.完整項目結構
8.啟動項目進行測試
第一次在瀏覽器中進行訪問,會看到瀏覽器中的username=null,并且控制臺中展示的log信息為“用戶不存在”,說明此時還沒有創建出session。但是當第一次訪問之后,session就被創建出來了,并且被存儲到了redis中,實現了持久化存儲??梢钥慈缦聢D:
第二次訪問,就會看到username已經可以獲取到新的信息了。
log控制臺中也看到已經提示“用戶存在”的信息了。
并且我們可以看到Redis控制臺中,提示了TTL過期時間是3660,每隔1秒鐘刷新1次,3600秒后過期。
此時我們可以分別啟動一個8080和8081進程,在兩個進程上分別測試session接口。
#進入到項目的target目錄下,執行java -jar命令,部署我們的jar包
F:\onlineWorks\boot-demos\demo43_springsession\target>java -jar demo43_springsession-1.0-SNAPSHOT.jar --server.port=8080
F:\onlineWorks\boot-demos\demo43_springsession\target>java -jar demo43_springsession-1.0-SNAPSHOT.jar --server.port=8081
在瀏覽器中,我們的8080和8081端口上訪問時,可以看到有一個共同的Session信息:
可以看到在兩個不同的進程端口上,都分別訪問到了同一個session信息,說明我們實現了分布式進程中session共享??梢娫谟辛薙pring Session后,實現session共享還是很簡單得到。
關于SpringBoot實現Session共享的方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。