詳解SpringBoot如何優(yōu)雅的處理免登錄接口
在項(xiàng)目開發(fā)過程中,會(huì)有很多API接口不需要登錄就能直接訪問,比如公開數(shù)據(jù)查詢之類的 ~
常規(guī)處理方法基本是 使用攔截器或過濾器,攔截需要認(rèn)證的請(qǐng)求路徑。在攔截器中判斷session或token信息,如果存在則放行,否則跳轉(zhuǎn)到登錄頁。過濾器原理與攔截器類似,可以在過濾器中判斷請(qǐng)求的session或token信息,麻煩的地方就是:每次開發(fā)新的免登錄接口的時(shí)候,都需要去配置一下路徑
今天介紹一個(gè)更優(yōu)雅的方法:自定義注解的方式
基本思路是:自定義一個(gè)注解,在不需要校驗(yàn)登錄的Controller方法或類上使用該注解。通過AOP或攔截器在方法執(zhí)行前判斷免登錄狀態(tài)
自定義注解這里命名為NoToken
import java.lang.annotation.*; /** * 不校驗(yàn)token注解 */ @Target({ElementType.METHOD,ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Documented public @interface NoToken { String name() default ""; }
這里采用攔截器搭配使用,攔截器代碼如下
@Slf4j public class SessionInterceptor implements HandlerInterceptor { //在請(qǐng)求處理之前進(jìn)行調(diào)用Controller方法調(diào)用之前 @Override @Reference public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { if (handler instanceof HandlerMethod) { HandlerMethod handlerMethod = (HandlerMethod) handler; NoToken classAnno = handlerMethod.getMethod().getDeclaringClass().getAnnotation(NoToken.class); //獲取出Controller上的NoToken注解 if (classAnno != null) { // 如果注解不為null, 說明不需要攔截, 直接放過 return true; } else { Method method = handlerMethod.getMethod(); handlerMethod.getMethodAnnotation(NoToken.class); //獲取出方法上的NoToken注解 NoToken access = method.getAnnotation(NoToken.class); if (access != null) { // 如果注解不為null, 說明不需要攔截, 直接放過 return true; } } } RedisService redis = (RedisService) SpringContextUtils.getBean("redisService"); String token = request.getHeader("token"); boolean ok = false; log.info("開始檢驗(yàn)token!"); if (!StringUtils.isEmpty(token)) { if (redis.exists(token)) { redis.expire(token, ConstantsUtil.APP_TOKEN_EXPIRE); log.info("token有效!"); ok = true; } } if (!ok) { Map<String, Object> result = new HashMap<>(); result.put("returncode","-1"); result.put("returnmsg", "登錄已過期,請(qǐng)重新登錄"); writeJSON(response, result); return ok; } return ok; } @Override public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception { } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception e) throws Exception { } public void writeJSON(HttpServletResponse response, Object o) throws IOException { response.setContentType("text/html;charset=UTF-8"); PrintWriter out = response.getWriter(); String JsonString = JSON.toJSONString(o); out.write(JsonString); } }
大家看到在NoToken注解和攔截器上,做了兩種處理 也就是類注解 和 方法注解
如果注解放到方法上,該方法調(diào)用的時(shí)候就是免登錄的。如果注解放到@Controller類上,那么該類下的所有請(qǐng)求接口,都是免登錄的(是不是很方便 ~)
/** * 類上加NoToken注解,該類下所有方法都免登錄 */ @NoToken @Slf4j @RestController @RequestMapping("/test") public class TestController { /** * 方法上單獨(dú)加注解,只對(duì)該方法免登錄 */ @NoToken @RequestMapping("testMethod") public void testMethod() { System.out.println("1111111111111"); } }
以上就是實(shí)現(xiàn)方式,如果覺得還有用,就點(diǎn)個(gè)贊吧 ~
到此這篇關(guān)于詳解SpringBoot如何優(yōu)雅的處理免登錄接口的文章就介紹到這了,更多相關(guān)SpringBoot處理免登錄接口內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java代碼性能測(cè)試實(shí)戰(zhàn)之ContiPerf安裝使用
這篇文章主要為大家介紹了Java代碼性能測(cè)試實(shí)戰(zhàn)之ContiPerf安裝使用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06java使用freemarker模板生成html再轉(zhuǎn)為pdf
這篇文章主要為大家詳細(xì)介紹了java如何使用freemarker模板生成html,再利用iText將生成的HTML轉(zhuǎn)換為PDF文件,感興趣的小伙伴可以參考下2025-04-04基于SpringBoot和Vue的動(dòng)態(tài)語音播放實(shí)現(xiàn)
本文介紹如何使用SpringBoot和Vue實(shí)現(xiàn)音頻文件的動(dòng)態(tài)播放,包括前端頁面設(shè)計(jì)、后端接口開發(fā)、音頻文件存儲(chǔ)和調(diào)用等方面。通過該實(shí)現(xiàn),用戶可以在網(wǎng)頁上直接播放音頻,增強(qiáng)用戶體驗(yàn),提高網(wǎng)站互動(dòng)性2023-04-04SpringMVC基于注解方式實(shí)現(xiàn)上傳下載
本文主要介紹了SpringMVC基于注解方式實(shí)現(xiàn)上傳下載,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04Spring打包jar包時(shí)jsp頁面無法訪問問題解決
這篇文章主要介紹了Spring打包jar包時(shí)jsp頁面無法訪問問題解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05