package com.yeshi.buwan.aspect;
|
|
import org.aspectj.lang.ProceedingJoinPoint;
|
import org.aspectj.lang.annotation.Around;
|
import org.aspectj.lang.annotation.Aspect;
|
import org.slf4j.Logger;
|
import org.slf4j.LoggerFactory;
|
import org.springframework.stereotype.Component;
|
import org.springframework.web.context.request.RequestContextHolder;
|
import org.springframework.web.context.request.ServletRequestAttributes;
|
|
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletResponse;
|
|
/**
|
* 跨域
|
*/
|
@Component
|
@Aspect()
|
public class CrossOriginAspect {
|
private final Logger logger = LoggerFactory.getLogger(CrossOriginAspect.class);
|
|
@Around("execution(public * com.yeshi.buwan.controller..*.*(..))")
|
public Object crossOrigin(ProceedingJoinPoint joinPoint) throws Throwable {
|
ServletRequestAttributes servletContainer = (ServletRequestAttributes) RequestContextHolder
|
.getRequestAttributes();
|
HttpServletResponse response = servletContainer.getResponse();
|
HttpServletRequest request = servletContainer.getRequest();
|
String origin = request.getHeader("Origin");
|
response.setHeader("Access-Control-Allow-Origin", origin);
|
response.setHeader("Access-Control-Allow-Methods", "*"); // 任何方法
|
response.setHeader("Access-Control-Allow-Credentials", "true");// 允许传递cookie
|
response.setHeader("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
|
|
return joinPoint.proceed();
|
}
|
|
}
|