應(yīng)用市場(chǎng)中Java攔截器和切面的使用實(shí)例詳解
相信大家對(duì)攔截器和切面的概念已經(jīng)不陌生了,本文我們就看一些在應(yīng)用市場(chǎng)中,攔截器和切面的使用是怎樣的。
攔截器的使用:每次接收到某個(gè)請(qǐng)求之前,都會(huì)調(diào)用此攔截器中的方法,其中preHandle方法如果return true,表示繼續(xù)調(diào)用對(duì)應(yīng)的controller,如果return false,
public class CheckLoginInterceptor implements HandlerInterceptor {
private Logger logger = Logger.getLogger(CheckLoginInterceptor.class);
private static String TOKEN_VALID_MSG ;
static
{
TOKEN_VALID_MSG=JsonUtil.writeObject2JSON(new AMSResultVO(CodeNum.TOKEN_VALID, CodeMessage.TOKEN_VALID));
}
public Boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
//request.getMethod獲取請(qǐng)求是get,post等
if ("OPTIONS".equals(request.getMethod()))
{
// 指定允許其他域名訪問(wèn)
response.setHeader("Access-Control-Allow-Origin", "*");
// 響應(yīng)類型
response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE");
// 響應(yīng)頭設(shè)置
response.setHeader("Access-Control-Allow-Headers", "Content-Type, x-requested-with, X-Custom-Header");
response.setStatus(204);
return true;
}
// 獲取從header中得到的數(shù)據(jù)
String userName = request.getHeader(CommonConsts.PARAM_USER_NAME);
String userToken = request.getHeader(CommonConsts.PARAM_USER_TOKEN);
Boolean result = true;
String method = request.getRequestURI();
if(method.equals("/ams/fileUpload"))
{
return true;
}
if(StringUtil.isEmpty(userName) || StringUtil.isEmpty(userToken))
{
result = false;
} else
{
result = TokenUtil.validToken(userName, userToken);
}
// token校驗(yàn)失敗
if(!result)
{
response.setContentType("text/html;charset=UTF-8");
response.getWriter().print(TOKEN_VALID_MSG);
response.getWriter().flush();
response.getWriter().close();
}
return result;
}
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
}
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
}
}
切面的使用:
//壞繞通知:需要攜帶ProceedingJoinPoint類型的參數(shù)
//環(huán)繞通知類似于動(dòng)態(tài)代理的全過(guò)程:ProceedingJoinPoint類型的參數(shù)可以決定是否執(zhí)行目標(biāo)方法
//且環(huán)繞通知必須有返回值,返回值即目標(biāo)方法的返回值。
@Around("execution(* com.sowell.controller.*Controller.*(..))")
public Object aroundMethod(ProceedingJoinPoint pjd) {
Object result = null;
String methodName = pjd.getSignature().getName();
Object args = Arrays.asList(pjd.getArgs());
//執(zhí)行目標(biāo)方法
try {
logger.info("request channels begin, param{pageNum:" + methodName + ", pageSize:" + args);
//前置通知,表示在此之前的代碼會(huì)在調(diào)用controller之前調(diào)用
result = pjd.proceed();
recordOprationLog(result, methodName, result);
//后置通知
logger.info("Arround:The method "+ methodName+" ends");
}
catch (Throwable e) {
e.printStackTrace();
//異常通知
logger.error("Arround:The method "+ methodName+"occurs exception:"+e);
//throw new RuntimeException(e);
//不拋出異常的話,異常就被上面抓住,執(zhí)行下去,返回result,result值為null,轉(zhuǎn)換為int
}
//返回通知
logger.info("Arround:The method "+ methodName+" ends with the Result "+ result);
return result;
}
總結(jié)
以上就是本文關(guān)于應(yīng)用市場(chǎng)中Java攔截器和切面的使用實(shí)例詳解的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對(duì)本站的支持!
- Java中過(guò)濾器 (Filter) 和 攔截器 (Interceptor)的使用
- 聊聊java 過(guò)濾器、監(jiān)聽(tīng)器、攔截器的區(qū)別(終結(jié)篇)
- 通過(guò)實(shí)例解析java過(guò)濾器和攔截器的區(qū)別
- Java中的攔截器、過(guò)濾器、監(jiān)聽(tīng)器用法詳解
- 淺析JAVA中過(guò)濾器、監(jiān)聽(tīng)器、攔截器的區(qū)別
- 了解java Struts攔截器的相關(guān)操作
- 詳解java中spring里的三大攔截器
- Java中的Struts2框架攔截器之實(shí)例代碼
- Java攔截器和過(guò)濾器的區(qū)別分析
相關(guān)文章
SpringBoot+JavaMailSender實(shí)現(xiàn)騰訊企業(yè)郵箱配置
這篇文章主要介紹了SpringBoot+JavaMailSender實(shí)現(xiàn)騰訊企業(yè)郵箱配置,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
SpringMVC框架實(shí)現(xiàn)Handler處理器的三種寫(xiě)法
這篇文章主要介紹了SpringMVC框架實(shí)現(xiàn)Handler處理器的三種寫(xiě)法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02
jsch中ChannelShell與ChannelExec的區(qū)別及說(shuō)明
這篇文章主要介紹了jsch中ChannelShell與ChannelExec的區(qū)別及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07
springboot+Oauth2實(shí)現(xiàn)自定義AuthenticationManager和認(rèn)證path
本篇文章主要介紹了springboot+Oauth2實(shí)現(xiàn)自定義AuthenticationManager和認(rèn)證path,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-09-09
Spring RabbitMQ死信機(jī)制原理實(shí)例詳解
這篇文章主要介紹了Spring RabbitMQ死信機(jī)制原理實(shí)例詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-03-03

