多语言展示
当前在线:1387今日阅读:19今日分享:20

Access-Control-Allow-Origin跨域问题

开发模式上想前后端分离,但是在使用axios交换数据的时候,提示Access-Control-Allow-Origin跨域问题,解决方案跟客户端没关系,修改的是服务端,使用cors filter,下面详细介绍调试过程
工具/原料
1

java

2

cors-filter2.6

3

axios^0.16.2

4

vue^2.4.2

故障
1

前端使用axios调用后台链接,请求服务端数据

3

请求异常,报错Access-Control-Allow-Origin,经查属于跨域问题,该问题不解决,前后端就不能各自愉快的工作了,因此要想办法解决掉

解决方案-后台
1

跨域问题属于后台的安全拦截,跟客户端没关系,在java后台,使用cors filter进行拦截处理,引用maven库cors-filter

2

修改web.xml,增加cors过滤器,在cors.supportedHeaders节点中,增加Access-Control-Allow-Origin,该处也可以改成*

3

  CORS   com.thetransactioncompany.cors.CORSFilter        cors.allowOrigin      *          cors.supportedMethods      GET, POST, HEAD, PUT, DELETE          cors.supportedHeaders      Accept, Origin, X-Requested-With, Content-Type, Last-Modified, Access-Control-Allow-Origin          cors.exposedHeaders      Set-Cookie          cors.supportsCredentials      true     CORS   /*

4

cors.allowOrigin:可以通过的ip,*代表所有,可以使用指定的ip,多个的话可以用逗号分隔,默认为*cors.supportedMethods:请求方式 默认为*cors.supportedHeaders:请求支持的头信息,默认为*cors.exposedHeaders:暴露的头信息,默认的empy listcors.supportsCredentials:支持证书,默认为truecors.maxAge: 最大过期时间,默认为-1cors.tagRequests: 默认为falsecors.allowSubdomains:允许子域 默认为false详细设置,可参考官网:http://software.dzhuvinov.com/cors-filter-configuration.html

5

服务端修改后,重启tomcat

解决方案-前端

在headers里面,要加入'Access-Control-Allow-Origin': '*',否则访问依然报错

推荐信息