Springboot通過請求頭獲取當前用戶信息方法詳細示范
一、實現(xiàn)原理
1、token的存儲
當用戶登錄時,將<token, userInfo>存入redis緩存中,以便鑒權(quán)與獲取用戶信息。
2、發(fā)送請求
每次發(fā)送請求時將token放入請求頭中,令key為“Authorization”或其他值。
3、獲取請求頭部
ServletRequestAttributes sra = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes(); HttpServletRequest request = sra.getRequest();
4、用戶請求頭部攜帶的token在redis中獲得userInfo
二、導(dǎo)入依賴
1、redis相關(guān)依賴
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-pool2</artifactId> </dependency>
2、fastjson
<dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> </dependency>
3、mybatis-plus
<dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus</artifactId> </dependency> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> </dependency>
三、配置文件
server:
port: 10002
spring:
datasource:
url: jdbc:mysql://localhost:3306/myDB?characterEncoding=utf-8&serverTimezone=Asia/Shanghai
username: <用戶名>
password: <密碼>
driver-class-name: com.mysql.cj.jdbc.Driver
redis:
#數(shù)據(jù)庫索引
database: 0
host: 127.0.0.1
password: <密碼>
jedis:
pool:
max-idle: 300
max-active: 600
max-wait: 1000
timeout: 3600
port: 6379
pool:
maxTotal: 1000
testOnBorrow: true
四、代碼實現(xiàn)
1、RedisUtil
import org.springframework.data.redis.core.StringRedisTemplate; import org.springframework.stereotype.Component; import javax.annotation.Resource; import java.util.concurrent.TimeUnit; /** * redis工具類 */ @Component public class RedisUtil { @Resource private StringRedisTemplate stringRedisTemplate; /** * 指定緩存失效時間 * * @param key 鍵 * @param time 時間(秒) * @return true or false */ public Boolean expire(final String key, final long time) { stringRedisTemplate.afterPropertiesSet(); try { if (time > 0) { stringRedisTemplate.expire(key, time, TimeUnit.SECONDS); } return true; } catch (final Exception e) { e.printStackTrace(); return false; } } /** * 普通緩存獲取 * * @param key 鍵 * @return 值 */ public Object get(final String key) { stringRedisTemplate.afterPropertiesSet(); return key == null ? null : stringRedisTemplate.opsForValue().get(key); } /** * 普通緩存放入 * * @param key 鍵 * @param value 值 * @return true成功 false失敗 */ public Boolean set(final String key, final String value) { stringRedisTemplate.afterPropertiesSet(); try { stringRedisTemplate.opsForValue().set(key, value); return true; } catch (final Exception e) { e.printStackTrace(); return false; } } /** * 普通緩存放入并設(shè)置時間 * * @param key 鍵 * @param value 值 * @param time 時間(秒) time要大于0 如果time小于等于0 將設(shè)置無限期 * @return true成功 false 失敗 */ public Boolean set(final String key, final String value, final long time) { stringRedisTemplate.afterPropertiesSet(); try { if (time > 0) { stringRedisTemplate.opsForValue().set(key, value, time, TimeUnit.SECONDS); } else { set(key, value); } return true; } catch (final Exception e) { e.printStackTrace(); return false; } } /** * 刪除鍵 * @param key 鍵 * @return true or false */ public Boolean del(final String key) { stringRedisTemplate.afterPropertiesSet(); try { stringRedisTemplate.opsForHash().delete(key); return true; } catch (final Exception e) { e.printStackTrace(); return false; } } }
2、TokenUtil
import java.util.UUID; public class TokenUtil { public static String generateToken() { //生成唯一不重復(fù)的字符串 return UUID.randomUUID().toString(); } }
3、UserHelper
import com.alibaba.fastjson.JSONObject; import com.example.commons.utils.MyStringUtils; import com.example.commons.utils.ObjectUtil; import com.example.commons.utils.RedisUtil; import com.example.commons.vo.UserVO; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import org.springframework.web.context.request.RequestContextHolder; import org.springframework.web.context.request.ServletRequestAttributes; import javax.servlet.http.HttpServletRequest; @Component public class UserHelper { @Autowired private RedisUtil redisUtil; /** * 獲取當前用戶的信息 * @return userVO */ public UserVO getCurrentUser() { ServletRequestAttributes sra = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes(); if (sra == null) { return null; } HttpServletRequest request = sra.getRequest(); return getCurrentUser(request); } /** * 通過請求獲取當前用戶信息 * @param request 請求 * @return userVO */ public UserVO getCurrentUser(HttpServletRequest request) { String token = request.getHeader("Authorization"); if (MyStringUtils.isBlank(token)) { return null; } return getCurrentUserByToken(token); } /** * 通過token獲取當前用戶信息 * @param token token * @return userVO */ public UserVO getCurrentUserByToken(String token) { String context = (String) redisUtil.get(token); if (MyStringUtils.isBlank(context)) { return null; } try { return JSONObject.parseObject(context, UserVO.class); } catch (Exception e) { e.printStackTrace(); } return null; } /** * 獲取當前用戶的id * @return 用戶id */ public Long getCurrentUserId() { UserVO userVO = getCurrentUser(); if (ObjectUtil.isNull(userVO)) { return null; } return userVO.getId(); } /** * 獲取當前請求 * @return request */ public HttpServletRequest getHttpServletRequest() { ServletRequestAttributes sra = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes(); if (sra == null) { return null; } return sra.getRequest(); } }
以上代碼中提到的UserVO、MyStringUtil、ObjectUtil均為本人自定義,比較簡單且與主題關(guān)聯(lián)不大,就不占用篇幅了。
4、登錄
@PostMapping("/login") public RestResponseEntity Login(@RequestParam("id") Long id) { // 此處簡化操作,只要用戶id存在即視為登錄成功 User user = userService.getUserById(id); if (ObjectUtil.isNull(user)) { return RestResponseEntity.fail("登錄失敗"); } UserVO userVO = new UserVO(); userVO.setId(user.getId()); userVO.setName(user.getUName()); // 將userVO序列化轉(zhuǎn)成json字符串 String userContext = JSON.toJSONString(userVO); // 隨機生成一個token String token = TokenUtil.generateToken(); // 將token與userContext存入redis redisUtil.set(token, userContext); return RestResponseEntity.success(token); // 此處響應(yīng)體為自定義 }
5、調(diào)用getCurrentUser實例
import com.example.commons.vo.UserVO; import com.example.reader.Helper.UserHelper; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @RestController @RequestMapping("/user") public class UserController { @Autowired private UserHelper userHelper; @GetMapping("/getUser") public UserVO getUser() { return userHelper.getCurrentUser(); } }
6、測試
(1)登錄測試
請求成功,token與userInfo也已寫入redis
(2)獲得當前用戶信息
五、總結(jié)
用這種方法獲取當前用戶信息,只需要一句簡單的
UserVO userVO =userHelper.getCurrentUser();
而不需要在controller或者其他業(yè)務(wù)代碼中獲取http頭部,更加整潔。并且將一些用戶常用的信息存入redis中,可以減少檢索數(shù)據(jù)庫的次數(shù),一定程度上可以提高效率。
到此這篇關(guān)于Springboot通過請求頭獲取當前用戶信息方法詳細示范的文章就介紹到這了,更多相關(guān)Springboot請求頭獲取用戶信息內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringBoot中獲取微信用戶信息的方法
- SpringBoot+SpringCloud用戶信息微服務(wù)傳遞實現(xiàn)解析
- Springboot+Shiro記錄用戶登錄信息并獲取當前登錄用戶信息的實現(xiàn)代碼
- SpringBoot使用Redis的zset統(tǒng)計在線用戶信息
- SpringBoot登錄、退出、獲取用戶信息的session處理方案
- springboot如何完美通過token獲取用戶信息
- springboot登錄攔截器+ThreadLocal實現(xiàn)用戶信息存儲的實例代碼
- SpringBoot通過參數(shù)注解自動獲取當前用戶信息的方法
- SpringBoot中的ThreadLocal保存請求用戶信息的實例demo
- springboot獲取當前用戶信息的三種方式
相關(guān)文章
使用JWT創(chuàng)建解析令牌及RSA非對稱加密詳解
這篇文章主要介紹了JWT創(chuàng)建解析令牌及RSA非對稱加密詳解,JWT是JSON Web Token的縮寫,即JSON Web令牌,是一種自包含令牌,一種情況是webapi,類似之前的阿里云播放憑證的功能,另一種情況是多web服務(wù)器下實現(xiàn)無狀態(tài)分布式身份驗證,需要的朋友可以參考下2023-11-11SpringSecurity構(gòu)建基于JWT的登錄認證實現(xiàn)
這篇文章主要介紹了SpringSecurity構(gòu)建基于JWT的登錄認證實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02Springboot+Vue+axios實現(xiàn)文章收藏功能
這篇文章主要為大家詳細介紹了Springboot+Vue+axios實現(xiàn)文章收藏功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-08-08