应用市场中Java拦截器和切面的使用实例详解
相信大家对拦截器和切面的概念已经不陌生了,本文我们就看一些在应用市场中,拦截器和切面的使用是怎样的。
拦截器的使用:每次接收到某个请求之前,都会调用此拦截器中的方法,其中preHandle方法如果returntrue,表示继续调用对应的controller,如果returnfalse,
publicclassCheckLoginInterceptorimplementsHandlerInterceptor{
privateLoggerlogger=Logger.getLogger(CheckLoginInterceptor.class);
privatestaticStringTOKEN_VALID_MSG;
static
{
TOKEN_VALID_MSG=JsonUtil.writeObject2JSON(newAMSResultVO(CodeNum.TOKEN_VALID,CodeMessage.TOKEN_VALID));
}
publicBooleanpreHandle(HttpServletRequestrequest,HttpServletResponseresponse,Objecthandler)throwsException{
//request.getMethod获取请求是get,post等
if("OPTIONS".equals(request.getMethod()))
{
//指定允许其他域名访问
response.setHeader("Access-Control-Allow-Origin","*");
//响应类型
response.setHeader("Access-Control-Allow-Methods","POST,GET,OPTIONS,DELETE");
//响应头设置
response.setHeader("Access-Control-Allow-Headers","Content-Type,x-requested-with,X-Custom-Header");
response.setStatus(204);
returntrue;
}
//获取从header中得到的数据
StringuserName=request.getHeader(CommonConsts.PARAM_USER_NAME);
StringuserToken=request.getHeader(CommonConsts.PARAM_USER_TOKEN);
Booleanresult=true;
Stringmethod=request.getRequestURI();
if(method.equals("/ams/fileUpload"))
{
returntrue;
}
if(StringUtil.isEmpty(userName)||StringUtil.isEmpty(userToken))
{
result=false;
}else
{
result=TokenUtil.validToken(userName,userToken);
}
//token校验失败
if(!result)
{
response.setContentType("text/html;charset=UTF-8");
response.getWriter().print(TOKEN_VALID_MSG);
response.getWriter().flush();
response.getWriter().close();
}
returnresult;
}
publicvoidpostHandle(HttpServletRequestrequest,HttpServletResponseresponse,Objecthandler,ModelAndViewmodelAndView)throwsException{
}
publicvoidafterCompletion(HttpServletRequestrequest,HttpServletResponseresponse,Objecthandler,Exceptionex)throwsException{
}
}
切面的使用:
//坏绕通知:需要携带ProceedingJoinPoint类型的参数
//环绕通知类似于动态代理的全过程:ProceedingJoinPoint类型的参数可以决定是否执行目标方法
//且环绕通知必须有返回值,返回值即目标方法的返回值。
@Around("execution(*com.sowell.controller.*Controller.*(..))")
publicObjectaroundMethod(ProceedingJoinPointpjd){
Objectresult=null;
StringmethodName=pjd.getSignature().getName();
Objectargs=Arrays.asList(pjd.getArgs());
//执行目标方法
try{
logger.info("requestchannelsbegin,param{pageNum:"+methodName+",pageSize:"+args);
//前置通知,表示在此之前的代码会在调用controller之前调用
result=pjd.proceed();
recordOprationLog(result,methodName,result);
//后置通知
logger.info("Arround:Themethod"+methodName+"ends");
}
catch(Throwablee){
e.printStackTrace();
//异常通知
logger.error("Arround:Themethod"+methodName+"occursexception:"+e);
//thrownewRuntimeException(e);
//不抛出异常的话,异常就被上面抓住,执行下去,返回result,result值为null,转换为int
}
//返回通知
logger.info("Arround:Themethod"+methodName+"endswiththeResult"+result);
returnresult;
}
总结
以上就是本文关于应用市场中Java拦截器和切面的使用实例详解的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!