日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Spring Cloud Gateway 使用JWT工具類做用戶登錄校驗功能

瀏覽:255日期:2023-07-24 18:18:53
1. JWT測試

/** * @Auther: csp1999 * @Date: 2021/01/24/19:29 * @Description: JWT測試 */public class JwtTest { /** * 創建Jwt令牌: * * JWT = 頭部Header + 載荷playload + 簽名signature */ @Test public void testCreateJwt() { // 構建jwt令牌 // 1.頭部Header: 描述關于該JWT的最基本的信息,例如其類型以及簽名所用的算法等 JwtBuilder builder = Jwts.builder() .setId('8989') // 設置令牌唯一編號 .setIssuer('csp1999') // 設置令牌頒發者 .setSubject('JWT加密測試') // 設置令牌主題 可以是JSON數據 .setIssuedAt(new Date()) // 設置令牌簽發日期 .setExpiration(new Date(System.currentTimeMillis() + 1000 * 60 * 3));// 設置令牌過期時間 3分鐘 // 2.自定義載荷playload: 存放有效信息的地方 Map<String,Object> userInfo = new HashMap<>(); userInfo.put('username','csp'); userInfo.put('password','123456'); userInfo.put('school','河南科技大學'); userInfo.put('age','22'); // 將載荷添加到JWT令牌中 builder.addClaims(userInfo); // 3.為令牌設置 簽名signature builder.signWith(SignatureAlgorithm.HS256, 'haust');// 設置令牌的簽名 使用HS256算法,并設置SecretKey密鑰(字符串) // 構建 并返回一個字符串 String jwtStr = builder.compact(); System.out.println(jwtStr); } /** * 解析Jwt令牌數據 */ @Test public void testParseJwt() { // jwt字符串 String jwtStr = 'eyJhbGciOiJIUzI1NiJ9.eyJqdGkiOiI4OTg5IiwiaXNzIjoiY3NwMTk5OSIsInN1YiI6IkpXVOWKoOWvhua1i-ivlSIsImlhdCI6MTYxMTQ4ODc1MSwiZXhwIjoxNjExNDg4OTMxLCJwYXNzd29yZCI6IjEyMzQ1NiIsInNjaG9vbCI6Iuays-WNl-enkeaKgOWkp-WtpiIsImFnZSI6IjIyIiwidXNlcm5hbWUiOiJjc3AifQ.uH28G9MSHfzaKBAOyr8AdksYLVvy8O5P8g7TORZIUFY'; // 解析jwt字符串 Claims claims = Jwts.parser(). setSigningKey('haust'). // 密鑰(鹽) parseClaimsJws(jwtStr). // 要解析的令牌對象 getBody(); // 獲取解析后的結果 // {jti=8989, iss=csp1999, sub=JWT加密測試, iat=1611488751, exp=1611488931, password=123456, school=河南科技大學, age=22, username=csp} System.out.println(claims); }}2. JWT工具類

/** * @Auther: csp1999 * @Date: 2021/01/24/19:29 * @Description: JWT工具類 */public class JwtUtil { // 有效期為 public static final Long JWT_TTL = 3600000L;// 60 * 60 * 1000 一個小時 // Jwt令牌信息 public static final String JWT_KEY = 'itcast'; /** * 生成令牌 * @param id * @param subject * @param ttlMillis * @return */ public static String createJWT(String id, String subject, Long ttlMillis) { // 指定算法 SignatureAlgorithm signatureAlgorithm = SignatureAlgorithm.HS256; // 當前系統時間 long nowMillis = System.currentTimeMillis(); // 令牌簽發時間 Date now = new Date(nowMillis); // 如果令牌有效期為null,則默認設置有效期1小時 if (ttlMillis == null) { ttlMillis = JwtUtil.JWT_TTL; } // 令牌過期時間設置 long expMillis = nowMillis + ttlMillis; Date expDate = new Date(expMillis); // 生成秘鑰 SecretKey secretKey = generalKey(); // 封裝Jwt令牌信息 JwtBuilder builder = Jwts.builder() .setId(id) //唯一的ID .setSubject(subject) // 主題 可以是JSON數據 .setIssuer('admin') // 簽發者 .setIssuedAt(now) // 簽發時間 .signWith(signatureAlgorithm, secretKey) // 簽名算法以及密匙 .setExpiration(expDate); // 設置過期時間 return builder.compact(); } /** * 生成加密 secretKey * * @return */ public static SecretKey generalKey() { byte[] encodedKey = Base64.getEncoder().encode(JwtUtil.JWT_KEY.getBytes()); SecretKey key = new SecretKeySpec(encodedKey, 0, encodedKey.length, 'AES'); return key; } /** * 解析令牌數據 * * @param jwt * @return * @throws Exception */ public static Claims parseJWT(String jwt) throws Exception { SecretKey secretKey = generalKey(); return Jwts.parser() .setSigningKey(secretKey) .parseClaimsJws(jwt) .getBody(); } public static void main(String[] args) { String jwt = JwtUtil.createJWT('weiyibiaoshi', 'aaaaaa', null); System.out.println(jwt); try { Claims claims = JwtUtil.parseJWT(jwt); System.out.println(claims); } catch (Exception e) { e.printStackTrace(); } }}3. 用戶登錄校驗

3.1 網關過濾器

/** * @Auther: csp1999 * @Date: 2021/01/24/20:17 * @Description: 授權過濾器 */@Componentpublic class AuthorizeFilter implements GlobalFilter, Ordered { // 令牌頭名字 private static final String AUTHORIZE_TOKEN = 'Authorization'; /** * 全局過濾器 * * @param exchange * @param chain * @return */ @Override public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) { // 獲取Request、Response對象 ServerHttpRequest request = exchange.getRequest(); ServerHttpResponse response = exchange.getResponse(); // 獲取請求的URI String path = request.getURI().getPath(); // 如果是登錄、goods等開放的微服務[這里的goods部分開放],則直接放行,這里不做完整演示,完整演示需要設計一套權限系統 // 未登錄下只放行登錄和搜索 if (path.startsWith('/api/user/login') || path.startsWith('/api/brand/search/')) { // 放行 Mono<Void> filter = chain.filter(exchange); return filter; } // 從頭文件中獲取的令牌信息 String token = request.getHeaders().getFirst(AUTHORIZE_TOKEN); // 如果為true:說明令牌在頭文件中, false:令牌不在頭文件中,將令牌封裝入頭文件,再傳遞給其他微服務 boolean hasToken = true; // 如果頭文件中沒有令牌信息,則從請求參數中獲取 if (StringUtils.isEmpty(token)) { token = request.getQueryParams().getFirst(AUTHORIZE_TOKEN); hasToken = false; } // 如果為空,則輸出錯誤代碼 if (StringUtils.isEmpty(token)) { // 設置方法不允許被訪問,405錯誤代碼 response.setStatusCode(HttpStatus.METHOD_NOT_ALLOWED); return response.setComplete(); } // 如果不為空,則解析令牌數據 try { Claims claims = JwtUtil.parseJWT(token); } catch (Exception e) { e.printStackTrace(); // 解析失敗,響應401錯誤 response.setStatusCode(HttpStatus.UNAUTHORIZED); return response.setComplete(); } // 放行之前,將令牌封裝到頭文件中(這一步是為了方便AUTH2校驗令牌) request.mutate().header(AUTHORIZE_TOKEN,token); // 放行 return chain.filter(exchange); } /** * 過濾器執行順序 * * @return */ @Override public int getOrder() { // 首位 return 0; }}

3.2 網關微服務application.yml

spring: cloud: gateway: globalcors: corsConfigurations: ’[/**]’: # 匹配所有請求 allowedOrigins: '*' # 跨域處理 允許所有的域 allowedMethods: #支持的請求類型 - GET - POST - PUT - DELETE routes: # 對接商品goods微服務路由相關配置 - id: changgou_goods_route uri: lb://changgou-goods predicates: - Path=/api/brand/**,/api/category/** filters: - StripPrefix=1 - name: RequestRateLimiter # 請求數限流 名字不能隨便寫 ,使用默認的facatory args: # 用于限流的鍵的解析器的 Bean 對象的名字。它使用 SpEL 表達式根據#{@beanName}從 Spring 容器中獲取 Bean 對象。 key-resolver: '#{@ipKeyResolver}' # 令牌桶每秒填充平均速率 redis-rate-limiter.replenishRate: 1 # 令牌桶總容量 redis-rate-limiter.burstCapacity: 1 # 上面配置,表示1秒內,允許 1個請求通過,令牌桶的填充速率也是1秒鐘添加1個令牌。 # 對接用戶user微服務路由相關配置 - id: changgou_user_route uri: lb://changgou-user predicates: - Path=/api/user/**,/api/address/**,/api/areas/**,/api/cities/**,/api/provinces/** filters: # user微服務真實請求中是沒有/api的,所以這里StripPrefix=1 - StripPrefix=1 # 微服務名稱 application: name: changgou-gateway-web # Redis配置 redis: # Redis數據庫索引(默認為0) database: 0 # Redis服務器地址 host: 8.131.66.136 # Redis服務器連接端口 port: 6379 # Redis服務器連接密碼(默認為空) password: csp19990129server: port: 8001eureka: client: service-url: defaultZone: http://127.0.0.1:7001/eureka instance: prefer-ip-address: truemanagement: endpoint: gateway: enabled: true web: exposure: include: true

3.3 網關微服務主啟動類

/** * @Auther: csp1999 * @Date: 2021/01/24/15:16 * @Description: 用戶/前臺微服務網關啟動類 */@SpringBootApplication@EnableEurekaClientpublic class GatewayWebApplication { public static void main(String[] args) { SpringApplication.run(GatewayWebApplication.class, args); } /** * IP限流:由用戶請求的IP創建創建用戶唯一標識,進而根據IP進行限流操作 * * @return */ @Bean(name = 'ipKeyResolver') public KeyResolver userKeyResolver() { return new KeyResolver() { @Override public Mono<String> resolve(ServerWebExchange exchange) { // 獲取遠程客戶端IP String hostName = exchange.getRequest().getRemoteAddress().getAddress().getHostAddress(); System.out.println('hostName:' + hostName); return Mono.just(hostName); } }; }}

3.4 用戶微服務編寫登錄代碼

/** * @Author: csp1999 * @Description: User 的Controller * @Date 2021/1/14 0:18 */@RestController@RequestMapping('/user')@CrossOriginpublic class UserController { @Autowired private UserService userService; /*** * 修改User數據 * @param user * @param id * @return */ @PutMapping(value = '/{id}') public Result update(@RequestBody User user, @PathVariable String id) { ... } /*** * 新增User數據 * @param user * @return */ @PostMapping public Result add(@RequestBody User user) { ... } /*** * 根據ID查詢User數據 * @param id * @return */ @GetMapping('/{id}') public Result<User> findById(@PathVariable String id) { ... } /*** * 查詢User全部數據 * @return */ @GetMapping public Result<List<User>> findAll() { ... } /*** * 用戶登錄 * @param username * @param password * @param response * @param request * @return */ @RequestMapping('/login') public Result<User> login(String username, String password, HttpServletResponse response, HttpServletRequest request) { // 1.從數據庫中查詢用戶名對應的用戶的對象 User user = userService.findById(username); if (user == null) { // 2.判斷用戶是否為空 為空返回數據 return new Result<User>(false, StatusCode.LOGINERROR, '用戶名或密碼錯誤...'); } // 3.如果不為空 判斷密碼是否正確 若正確 則登錄成功 if (BCrypt.checkpw(password, user.getPassword())) { // 登錄成功,講用戶信息存入map Map<String, Object> info = new HashMap<String, Object>(); info.put('role', 'USER'); info.put('success', 'SUCCESS'); info.put('username', username); // 3.1生成令牌 String jwt = JwtUtil.createJWT(UUID.randomUUID().toString(), JSON.toJSONString(info), null); // 3.2設置jwt存入 cookie 中 Cookie cookie = new Cookie('Authorization', jwt); response.addCookie(cookie); // 3.3設置jwt存入頭文件中 response.setHeader('Authorization', jwt); return new Result<User>(true, StatusCode.OK, '登錄成功', jwt); } else { // 登錄失敗 return new Result<User>(false, StatusCode.LOGINERROR, '用戶名或密碼錯誤'); } }}

到此這篇關于Spring Cloud Gateway 使用JWT工具類做用戶登錄校驗的示例代碼的文章就介紹到這了,更多相關Spring Cloud Gateway 用戶登錄校驗內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
色天使综合视频| 在线日韩一区| 日韩午夜黄色| 国产高清一区二区| 美女网站一区| 好看不卡的中文字幕| 亚洲成人二区| 天堂а√在线最新版中文在线| 高清不卡一区| 久久精品导航| 亚洲欧美日韩精品一区二区 | 日本亚洲不卡| 国产精品一卡| 国产调教精品| 成人国产精选| 久久在线电影| 日韩专区在线视频| 青青草伊人久久| 久久三级中文| 久久久久欧美精品| 亚洲一区不卡| 97成人超碰| 国产精品二区不卡| 蜜桃视频欧美| 亚洲精品麻豆| 麻豆91在线播放| 日本欧美不卡| 免费不卡在线观看| 97精品国产99久久久久久免费| 美女视频网站久久| 久久久久久久久丰满| 在线精品国产亚洲| 欧美交a欧美精品喷水| 91视频一区| 亚洲深爱激情| 国产激情一区| 欧美+亚洲+精品+三区| 日韩高清国产一区在线| 久久精品国产在热久久| 激情欧美一区| 青青草伊人久久| 黑人精品一区| 免费精品视频最新在线| 国产欧美日韩在线一区二区| 在线天堂中文资源最新版| 视频一区欧美精品| 国产福利资源一区| 狠狠操综合网| 国产精品主播在线观看| 欧美日韩第一| 国产欧美日韩精品一区二区三区| 日韩视频网站在线观看| 综合亚洲视频| 日韩国产一区二区三区| 少妇精品久久久一区二区| 成人一区而且| 色8久久久久| 精精国产xxxx视频在线野外 | 在线综合欧美| 麻豆精品视频在线观看免费| 精品亚洲美女网站| 69堂精品视频在线播放| 欧美日韩在线观看视频小说| 国产欧美一区二区三区米奇| 欧美日韩少妇| 国产69精品久久| 亚洲最新av| 日本久久成人网| 国产精品v一区二区三区| 欧美日韩国产欧| 国产在视频一区二区三区吞精| 男人操女人的视频在线观看欧美| 国产在线视频欧美一区| 婷婷精品在线| 亚洲国产成人精品女人| 久久精品色播| 亚洲毛片一区| 国产国产精品| 中文字幕在线视频网站| 国产精品nxnn| 一区二区三区四区精品视频| 欧美成a人免费观看久久| 国产精品一区二区精品| 免费日韩一区二区| 性感美女一区二区在线观看| 牛牛精品成人免费视频| 亚洲三级视频| 亚洲第一精品影视| 久久久久伊人| 欧美日韩一区二区国产| 西西人体一区二区| 久久青草久久| 超碰99在线| 另类综合日韩欧美亚洲| 青草国产精品| 亚洲字幕久久| 国产亚洲精品v| 激情久久五月| 91精品精品| 国产传媒在线观看| 国内精品美女在线观看| 国产精品大片| 91伊人久久| 四虎在线精品| 亚洲精品在线二区| 免费不卡在线视频| 亚洲综合丁香| 99视频一区| 中文久久精品| 国产精品普通话对白| 99国产精品| 99国产精品自拍| 激情婷婷综合| 黄色亚洲大片免费在线观看| 午夜久久福利| 欧美日韩免费观看一区=区三区| 亚洲先锋成人| 国产一区清纯| 亚洲先锋成人| 欧美日韩国产免费观看 | 日韩精品中文字幕一区二区| 亚洲精品乱码| 日本少妇一区二区| 国产日韩欧美三区| 国产精品日韩精品在线播放| 国产精品v一区二区三区| 国产精品成人**免费视频| 免费在线亚洲| 手机在线电影一区| 久久久久国产| 色天使综合视频| 91精品一区二区三区综合| 日韩精品一区二区三区免费观影 | 国产一区二区视频在线看| 黄色网一区二区| 久久男人av资源站| 一本大道色婷婷在线| 国产精品99一区二区三| 亚洲伊人av| 亚洲网站视频| 日韩制服丝袜先锋影音| 日韩精品欧美精品| 国产精品观看| av免费不卡国产观看| 久久中文字幕av| 香蕉成人久久| 青草国产精品| 国内精品伊人| 国产综合精品| 蜜桃视频在线观看一区| 欧美一级网站| 国产成人免费| 久久精品欧美一区| 蜜桃av一区| 国产欧美日韩精品一区二区免费| 久久久久伊人| 激情五月综合网| 婷婷精品在线| 日韩av二区| 亚洲一区二区三区高清不卡| 日本不卡视频在线| 久久久免费人体| 久久国产中文字幕| 伊人精品久久| 电影91久久久| 国产亚洲高清视频| 欧美激情一区| 激情综合网站| 国产私拍福利精品视频二区| 日韩在线高清| 视频国产精品| 亚洲三级欧美| 午夜久久av | 国产精品字幕| 亚洲精品影院在线观看| 精品成人18| 视频一区二区欧美| 老司机精品视频网| 狠狠久久婷婷| 久久久久亚洲精品中文字幕| 久久久久久美女精品| 日韩高清在线不卡| 夜鲁夜鲁夜鲁视频在线播放| 亚洲视频二区| 国产粉嫩在线观看| 在线观看一区| 不卡福利视频| 日韩精品五月天| 久久高清免费| 国产日韩精品视频一区二区三区| 欧美日韩国产v| 日韩av影院| 亚洲手机视频| 欧美精品二区| 蜜臀av亚洲一区中文字幕| 国产精品精品| 一区二区日韩免费看| 裤袜国产欧美精品一区| 日本aⅴ免费视频一区二区三区| 久久精品电影|