spring 프로젝트 에 도 메 인 접근 설정

3554 단어 spring자바
도 메 인 을 뛰 어 넘 는 것 은 흔히 말 하 는 문제 입 니 다.도 메 인 이름 이나 같은 도 메 인 이름 의 서로 다른 포트 에 도 도 도 메 인 접근 문제 가 발생 할 수 있 습 니 다.
해결 방안
1.전단 에 jsonp 방식 으로 요청 2,백 엔 드 에 응답 헤더 헤더 설정 3,Spring MVC 4.2+버 전 으로 크로스 도 메 인 지원(@CrossOrigin 주석 방식 또는 자체 설정)이 내장 되 어 있 습 니 다.
제 가 사용 하 는 spring mvc 4.0 은 두 번 째 방식 으로 차단기 에 따라 응답 헤드 를 설정 합 니 다.
import javax.servlet.*;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

/**
 * Created by Healist on 2017/1/31.
 */
public class CORSFilter implements Filter {
    public void init(FilterConfig filterConfig) throws ServletException {

    }

    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        HttpServletResponse response = (HttpServletResponse) servletResponse;
        response.setHeader("Access-Control-Allow-Origin", "*");
        response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE");
        response.setHeader("Access-Control-Max-Age", "3600");
        response.setHeader("Access-Control-Allow-Headers", "x-requested-with");
        filterChain.doFilter(servletRequest, servletResponse);
    }

    public void destroy() {

    }
}

웹.xml 중

  <filter>
    <filter-name>crossoriginfilter-name>
    <filter-class>com.healist.config.CORSFilterfilter-class>
  filter>
  <filter-mapping>
    <filter-name>crossoriginfilter-name>
    <url-pattern>/*url-pattern>
  filter-mapping>

저 는 여기 서 원생 의 차단기 로 직접 썼 습 니 다.사실은 spring mvc 도 자신의 차단 기 를 봉 했 습 니 다.국 을 바 꾸 지 않 고 약 을 바 꾸 지 않 는 것 은 일리 가 많 지 않 습 니 다.
spring mvc 차단기 추가:SpringMVC 차단기

좋은 웹페이지 즐겨찾기