日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

简单的实现登录拦截及统一异常处理(自定义异常)

發布時間:2023/12/18 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 简单的实现登录拦截及统一异常处理(自定义异常) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

webmvc配置類:

@Configuration public class WebMvcConfig extends WebMvcConfigurationSupport{@Overrideprotected void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(new LoginInterceptor()).addPathPatterns("/**").excludePathPatterns("/user/login");} }

注:registry.addInterceptor(攔截器類對象).addPathPatterns("需要攔截的請求路徑").excludePathPatterns("可以放行的請求路徑");

?

攔截器類,這里為登錄攔截

public class LoginInterceptor implements HandlerInterceptor{@Overridepublic void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3)throws Exception {// TODO Auto-generated method stub }@Overridepublic void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3)throws Exception {// TODO Auto-generated method stub }@Overridepublic boolean preHandle(HttpServletRequest hServletRequest, HttpServletResponse hServletResponse, Object object) throws Exception {// 案例采用session存儲登錄用戶,所以從session獲取登錄用戶
     HttpSession session
= hServletRequest.getSession();TUser tUser=(TUser)session.getAttribute("user");
// 判斷session里是否能取出用戶
if(tUser==null) {returnErrorMessage(hServletResponse, "當前操作需要先進行用戶登錄");return false;}return true;}private void returnErrorMessage(HttpServletResponse response, String errorMessage) throws IOException {response.setCharacterEncoding("utf-8");Map<String, Object> var=new HashMap<>();var.put("success", false);var.put("errorMessage", errorMessage);response.setContentType("application/json");PrintWriter out = response.getWriter();ObjectMapper mapper = new ObjectMapper();String jsonOfRST =mapper.writeValueAsString(var);out.print(jsonOfRST);out.flush();} }

到這里實現了簡單的登錄攔截,但是上面通過response對象獲取的輸出流來寫入錯誤信息,下面采用自定義異常來處理

?

異常類

public class UnloggedException extends RuntimeException{private static final long serialVersionUID = 181074719716690931L;public UnloggedException() {super("當前操作需要先進行登錄");} }

修改攔截器類的preHandle方法,于是returnErrorMessage方法可以去掉了

@Overridepublic boolean preHandle(HttpServletRequest hServletRequest, HttpServletResponse hServletResponse, Object object) throws Exception {HttpSession session = hServletRequest.getSession();TUser tUser=(TUser)session.getAttribute("user");if(tUser==null) {throw new UnloggedException();}return true;}

最后配置異常處理類

@ControllerAdvice @ResponseBody public class GlobalExceptionHandler {@ExceptionHandlerpublic JSONObject handleException(Exception e) {return ActionHelper.responseFailed(e.getMessage());} }

上面的返回值及ActionHelper為我使用的返回工具類,依賴為com.alibaba的fastjson,版本參考1.2.49。

可以根據實際情況修改返回方式及返回值。

此后所有的異常,都可以通過自定義異常的方式,交由異常處理類來進行處理,返回結果。

轉載于:https://www.cnblogs.com/it-taosir/p/9716028.html

總結

以上是生活随笔為你收集整理的简单的实现登录拦截及统一异常处理(自定义异常)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。