没有合适的资源?快使用搜索试试~ 我知道了~
资源推荐
资源详情
资源评论
应用市场中应用市场中Java拦截器和切面的使用实例详解拦截器和切面的使用实例详解
主要介绍了应用市场中Java拦截器和切面的使用实例详解,具有一定借鉴价值,需要的朋友可以参考下
相信大家对拦截器和切面的概念已经不陌生了,本文我们就看一些在应用市场中,拦截器和切面的使用是怎样的。
拦截器的使用:每次接收到某个请求之前,都会调用此拦截器中的方法,其中preHandle方法如果return true,表示继续调用对
应的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获取请求是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);
return true;
}
// 获取从header中得到的数据
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校验失败
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类型的参数
//环绕通知类似于动态代理的全过程:ProceedingJoinPoint类型的参数可以决定是否执行目标方法
//且环绕通知必须有返回值,返回值即目标方法的返回值。
@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());
//执行目标方法
try {
logger.info("request channels begin, param{pageNum:" + methodName + ", pageSize:" + args);
//前置通知,表示在此之前的代码会在调用controller之前调用
result = pjd.proceed();
recordOprationLog(result, methodName, result);
//后置通知
资源评论
weixin_38500607
- 粉丝: 4
- 资源: 965
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功