欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

Apache跨域资源访问报错问题解决方案

程序员文章站 2022-06-25 17:32:21
很多时候,大中型网站为了静态资源分布式部署,加快访问速度,减轻主站压力,会把静态资源(例如字体文件、图片等)放在独立服务器或者cdn上,并且使用独立的资源域名(例如res.test.com)但是在实际...

很多时候,大中型网站为了静态资源分布式部署,加快访问速度,减轻主站压力,会把静态资源(例如字体文件、图片等)放在独立服务器或者cdn上,并且使用独立的资源域名(例如res.test.com)

但是在实际部署中,会发现浏览器无法载入这些不同域名的资源,firefox控制台会报错:

<span role="presentation" class="objectbox objectbox-errormessage "><span class="errormessage ">已阻止跨源请求:同源策略禁止读取位于 http://xxxxx 的远程资源。(原因:cors 头缺少 'access-control-allow-origin')。</span></span>

已阻止跨源请求:同源策略禁止读取位于 http://xxxxx 的远程资源。(原因:cors 请求失败)。

这是因为现代浏览器将其定义为跨域资源而不允许加载

理解跨域首先必须要了解同源策略。同源策略是浏览器上为安全性考虑实施的非常重要的安全策略。

何谓同源:

url由协议、域名、端口和路径组成,如果两个url的协议、域名和端口相同,则表示他们同源。

同源策略:

浏览器的同源策略,限制了来自不同源的"document"或脚本,对当前"document"读取或设置某些属性。 (白帽子讲web安全[1])
从一个域上加载的脚本不允许访问另外一个域的文档属性。

那么关键是如何解决呢,其实很简单,只要在静态资源服务器上,增加一个头信息:

access-control-allow-origin *

本文就apache进行操作,nginx大同小异

首先编辑httpd.conf

找到这行

#loadmodule headers_module modules/mod_headers.so

把#注释符去掉

loadmodule headers_module modules/mod_headers.so

目的是开启apache头信息自定义模块

然后在独立资源域名的虚拟主机添加一行

header set access-control-allow-origin *

意思是对这个域名的资源进行访问时,添加一个头信息

重启apache

再访问,ok!

namevirtualhost 10.0.0.2:80
<virtualhost 10.0.0.2:80>
  documentroot /var/www/host.example.com
  servername host.example.com
  jkmount /webapp/* jkworker
  header set access-control-allow-origin "*"
  rewriteengine on
  rewriterule  ^/otherhost http://otherhost.example.com/webapp [r,l]
</virtualhost>

and here's an example of the apache config for the second:

namevirtualhost 10.0.1.2:80
<virtualhost 10.0.1.2:80>
  documentroot /var/www/otherhost.example.com
  servername otherhost.example.com
  jkmount /webapp/* jkworker
  header set access-control-allow-origin "*"
</virtualhost>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。