SpringMVC 解决跨域和乱码问题

今天再做接口对接的时候,突然遇到了这个问题:

      我在Postman 中测试正常的接口,在前端那边突然出现了403跨域的问题,因此我在白度中找了好几种方法,其中比较简单有用的,解决了问题是如下方法: 

1; 新建类:

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.HttpServletResponse;

/**
 *@description  TODO 跨域解决类
 *@author  geYang
 **/
public class SimpleCORSFilter implements Filter{

    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        // TODO Auto-generated method stub
        
    }
    
    /**
     *  请求头注释:
     *  0: response.setCharacterEncoding("UTF-8"); 设置响应参数为UTF-8
     *  1: Access-Control-Allow-Origin 可以请求的域; *为允许所有域请求
     *  2: Access-Control-Allow-Methods 请求方式
     *  3: Access-Control-Max-Age  请求数据缓存时间(单位秒)
     *  4: Access-Control-Allow-Credentials 保持跨域 AJAX时的 Cookie
     *  5: Access-Control-Allow-Headers 请求头:
     *      (1): X-Requested-With 请求头用于在服务器端判断request来自AJAX请求还是传统请求;
     **/
    @Override
    public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain)
            throws IOException, ServletException {
        // TODO 解决跨域错误
        HttpServletResponse response = (HttpServletResponse) resp;
        response.setCharacterEncoding("UTF-8");
        response.setHeader("Access-Control-Allow-Credentials", "true");
        response.setHeader("Access-Control-Allow-Headers", "X-Requested-With");
        response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE");
        response.setHeader("Access-Control-Allow-Origin", "*");
        response.setHeader("Access-Control-Max-Age", "600");
        chain.doFilter(req, resp);
    }

    @Override
    public void destroy() {
        // TODO Auto-generated method stub
        
    }

    
    
}

2: 在 web.xml 中进行配置:

<!-- 
		org.springframework.web.filter.CharacterEncodingFilter
	 -->
	<filter>
		<filter-name>SetCharacterEncoding</filter-name>
		<filter-class>
			com.xt.shop.base.interceptor.SimpleCORSFilter
		</filter-class>
		<init-param>
			<param-name>encoding</param-name>
			<param-value>UTF-8</param-value>
		</init-param>
		<init-param>
			<param-name>forceEncoding</param-name>
			<param-value>true</param-value>
		</init-param>
	</filter>
	<filter-mapping>
        <filter-name>SetCharacterEncoding</filter-name>
		<url-pattern>/*</url-pattern>
	</filter-mapping>

这样跨域问题就解决了, 但 Controller 层中接收参数出现了中文乱码情况;

解决方法为: 在拦截器中加入:

        //设置接收编码为UTF-8
        request.setCharacterEncoding("UTF-8");

这句代码就可以啦...

转载于:https://my.oschina.net/u/3681868/blog/1583575

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值