springcloud如何獲取網關封裝的頭部信息
更新時間:2022年06月17日 10:35:32 作者:一一可可
這篇文章主要介紹了springcloud獲取網關封裝的頭部信息,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
后臺系統(tǒng)如何獲取請求頭里的數據
1. 網關層封裝數據到head頭
@Component @Slf4j public class LoginGatewayFilterFactory extends AbstractGatewayFilterFactory { @Override public GatewayFilter apply(Object config) { return (exchange, chain) -> { // 獲取 request ServerHttpRequest req = exchange.getRequest(); URI uri = req.getURI(); // 日志 log.info(StringUtils.join("【", req.getMethod(), "】", uri.getHost(), ":", uri.getPort(), ", 【path】", uri.getPath())); // 檢查請求 uri 是否需要鑒權 String path = uri.getPath(); if (StringUtils.equalsAny(path, "/sysLogin")) { return chain.filter(exchange); } // 獲取請求的 token HttpHeaders reqHeaders = req.getHeaders(); String token = req.getHeaders().getFirst("token"); if (StringUtils.isBlank(token)) { return FilterUtil.setParamToResponse(exchange, HttpStatus.UNAUTHORIZED, "請先登錄"); } // 驗證 token JWT jwt = JWTUtil.parseToken(token); if (jwt == null) { log.info(StringUtils.join("[token=", token, "]轉換為jwt失敗")); return FilterUtil.setParamToResponse(exchange, HttpStatus.UNAUTHORIZED, "令牌未識別"); } JSONObject json = jwt.getPayloads(); if (json == null || json.isEmpty() || json.isNull("key") || json.isNull(JWTPayload.ISSUED_AT)) { log.info(StringUtils.join("[token=", token, "]解析異常")); return FilterUtil.setParamToResponse(exchange, HttpStatus.UNAUTHORIZED, "令牌未識別"); } String userId = json.get("key", String.class); if (StringUtils.isBlank(userId)) { return FilterUtil.setParamToResponse(exchange, HttpStatus.UNAUTHORIZED, "令牌未識別"); } boolean verify = jwt.setKey(JwtUtils.createKey(userId)).verify(); if (!verify) { return FilterUtil.setParamToResponse(exchange, HttpStatus.UNAUTHORIZED, "令牌未識別"); } // 過期時間 long seconds = Instant.now().getEpochSecond() - json.get(JWTPayload.ISSUED_AT, Long.class); if (seconds < 0) { return FilterUtil.setParamToResponse(exchange, HttpStatus.UNAUTHORIZED, "令牌未識別"); } else if (seconds >= 1500 && seconds <= 1800) { // 自動刷新令牌 ServerHttpResponse httpResponse = exchange.getResponse(); HttpHeaders repHeaders = httpResponse.getHeaders(); repHeaders.set("token", JwtUtils.createToken(userId)); } else if (seconds > 1800) { // 登錄超時 return FilterUtil.setParamToResponse(exchange, HttpStatus.UNAUTHORIZED, "登錄超時"); } Consumer<HttpHeaders> headersConsumer = httpHeaders -> { for (Map.Entry<String, List<String>> entry : reqHeaders.entrySet()) { httpHeaders.put(entry.getKey(), entry.getValue()); } httpHeaders.add("userId", userId); }; return chain.filter(exchange.mutate().request(req.mutate().headers(headersConsumer).build()).build()); }; } }
2. controller層代碼實現(xiàn)
@ApiOperation(value = "添加") @PostMapping("") public PojoBaseResponse<Boolean> add(@RequestBody @Validated MainRouteDTO vo, @RequestHeader String userId) { return ResponseUtils.pojo(mainRouteService.add(vo, userId)); }
到此這篇關于springcloud獲取網關封裝的的文章就介紹到這了,更多相關springcloud網關頭部信息內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
解決RestTemplate加@Autowired注入不了的問題
這篇文章主要介紹了解決RestTemplate加@Autowired注入不了的問題,具有很好的參考價值,希望對大家有所幫助。2021-08-08Spring Cloud Alibaba 之 Nacos教程詳解
Nacos是阿里的一個開源產品,它是針對微服務架構中的服務發(fā)現(xiàn)、配置管理、服務治理的綜合性解決方案。這篇文章主要介紹了Spring Cloud Alibaba 之 Nacos的相關知識,需要的朋友可以參考下2020-11-11