react 使用 fetch 向spring mvc后台发起ajax 请求 options 403

前端之家收集整理的这篇文章主要介绍了react 使用 fetch 向spring mvc后台发起ajax 请求 options 403前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

http://www.tuicool.com/articles/3UBzIbb

spring mvc 支持options方法

增加如下配置:

<init-param>
<param-name>dispatchOptionsRequest</param-name>
<param-value>true</param-value>
</init-param>

加在springdispatcher 里面

<servlet>
<servlet-name>springdispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springMvc-viewresolver.xml</param-value>
</init-param>
<init-param>
<param-name>dispatchOptionsRequest</param-name>
<param-value>true</param-value>
</init-param>

<load-on-startup>1</load-on-startup>
</servlet>

过滤器代码

package com.allcam.andedu.abc.filter;

import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

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 com.allcam.andedu.abc.pojo.UserCache;

public class SystemFilter implements Filter
{

private static final List<String> STRINGS = new ArrayList<String>();

private static final String UTF8_CODE = "UTF-8";
static
{
STRINGS.add("jsp");
STRINGS.add("js");
STRINGS.add("css");
STRINGS.add("images");
STRINGS.add("backRes");
STRINGS.add("anon");
STRINGS.add("ckplayer");
STRINGS.add("htm");
STRINGS.add("ico");
STRINGS.add("uploadImage");
}

@Override
public void destroy()
{

}

@Override
public void doFilter(ServletRequest servletRequest,ServletResponse servletResponse,FilterChain chain)
throws IOException,ServletException
{
HttpServletRequest request = (HttpServletRequest)servletRequest;

HttpServletResponse response = (HttpServletResponse)servletResponse;
// 指定允许其他域名访问
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");


if ("OPTIONS".equals(request.getMethod())) { response.setStatus(204); } // response.setHeader("Access-Control-Max-Age","3600"); request.setCharacterEncoding(UTF8_CODE); response.setCharacterEncoding(UTF8_CODE); chain.doFilter(request,response); } @Override public void init(FilterConfig filterConfig) throws ServletException { } public boolean isAuth(String url) { for (String string : STRINGS) { if (url.contains(string)) { return true; } } return false; } }

猜你在找的React相关文章