java解决跨域

package com.example.demo.common.filter;

import java.io.IOException;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.stereotype.Component;

@Component
public class HeadersCORSFilter implements Filter{

	
	public HeadersCORSFilter() {}

	public void destroy() {}

	public void doFilter(ServletRequest request, ServletResponse servletResponse, FilterChain chain) throws IOException, ServletException {
		HttpServletRequest req = (HttpServletRequest) request;
		HttpServletResponse resp = (HttpServletResponse) servletResponse;
		String reqUrl = req.getHeader("Origin");
		this.crossDomain(req, resp, reqUrl);
		chain.doFilter(req, resp);
	}

	private void crossDomain(HttpServletRequest request, HttpServletResponse response, String url) {
		response.setHeader("Content-type", "text/html;charset=UTF-8");
		response.setCharacterEncoding("UTF-8");
		response.setHeader("Access-Control-Allow-Credentials", "true");
		response.setHeader("Access-Control-Allow-Origin", url );
		response.setHeader("Access-Control-Allow-Credentials", "true");
		response.setHeader("Access-Control-Allow-Methods", "GET, POST, OPTIONS,PUT,DELETE");
		response.setHeader("Access-Control-Allow-Headers",
		"Origin, No-Cache, X-Requested-With, If-Modified-Since, Pragma, Last-Modified, Cache-Control, Expires, Content-Type, X-E4M-With");
	}

	public void init(FilterConfig fConfig) throws ServletException {}

}

猜你喜欢

转载自blog.csdn.net/huiyanshizhen21/article/details/88539703