跨域策略文件crossdomain.xml的配置方法_houbin0912的博客-程序员秘密

技术标签: web  

一、crossdomain.xml文件的作用

    跨域,顾名思义就是需要的资源不在自己的域服务器上,需要访问其他域服务器。跨域策略文件是一个xml文档文件,主要是为web客户端(如Adobe Flash Player等)设置跨域处理数据的权限。打个比方说,公司A部门有一台公共的电脑,里面存放着一些资料文件,专门供A部门内成员自己使用,这样,A部门内的员工就可以访问该电脑,其他部门人员则不允许访问。如下图: 
这里写图片描述 
A部门的员工可以任意访问A部门的公共电脑,但是不能直接访问B部门的公共电脑。有一天,B部门领导觉得他们的资料非常有用,想要与A部门分享,于是就给A部门一个令牌,这样A部门的员工也可以访问B部门的公共电脑了。 
    换成系统,常见就如同下面所示: 
这里写图片描述 
上图是典型的跨域请求,业务服务器向图片服务器上传图片时就涉及到了跨域,要想能正常访问,图片服务器需要给业务服务器设置允许访问的权限。而这个权限设置就是跨域策略文件crossdomain.xml存在的意义。

二、配置规则

  • cross-domain-policy 
    cross-domain-policy元素是跨域策略文件crossdomain.xml的根元素。它只是一个策略定义的容器,没有自己的属性。子元素有: 
    • site-control
    • allow-access-from
    • allow-access-from-identity
    • allow-http-request-headers-from
  • site-control 
    site-control元素用于定义当前域的元策略。元策略则是用于指定可接受的域策略文件,且该文件不同于目标域根元素(名为crossdomain.xml)中的主策略文件。 
    如果客户端收到指示使用主策略文件以外的策略文件,则该客户端必须首先检查主策略的元策略,以确定请求的策略文件是否获得许可。 
    属性:

    • permitted-cross-domain-policies 
      指定元策略。除套接字策略文件外,所有策略文件的默认值均为master-only,套接字策略文件的默认值为all。该属性允许的值有: 
      • none:目标服务器上的任何位置(包括该主策略文件)均不允许使用策略文件。
      • master-only:仅允许这个主策略文件。
      • by-content-type:仅允许Content-Type:text/x-cross-domain-policy提供的策略文件(只适用于HTTP/HTTPS)。
      • by-ftp-filename:仅允许文件名为crossdomain.xml的策略文件。(只适用于FTP)
      • all:允许此目标域中所有的策略文件。
  • allow-access-from 
    allow-access-from元素用于授权发出请求的域从目标域中读取数据。可以通过使用通配符(*),为多个域设置访问权限。 
    属性:

    • domain:指定要授予访问权限的发出请求的域。可以是域名或IP地址。子域将被视为不同的域。指定域时可以使用通配符星号( * )表示多个域。单独使用星号( * )表示所有域。一般不建议设置为星号允许所有域访问。
    • to-ports:只适用于Sockets,以逗号分隔的端口列表,或者允许连接到套接字连接的一系列端口。端口范围通过在两个端口号之间插入短划线 (-) 指定。端口范围在用逗号隔开时则可以用于指代单个端口。一个通配符 (*) 可用于表示允许所有端口。
    • secure:只只适用于HTTPS和Sockets,指定仅授予指定来源的 HTTPS 文档的访问权限 (true),还是授予指定来源的所有文档的访问权限 (false)。如果 HTTPS 策略文件中未指定 secure,则默认为 true。不建议在 HTTPS 策略文件中使用 false,因为这会影响 HTTPS 的安全性。在套接字策略文件中,默认值为 false。只有当套接字服务器接受本地主机连接时,指定 secure=”true” 才有意义,因为本地套接字连接通常不会面临中间人攻击的风险,因此无法更改 secure=”true” 声明。
  • allow-access-from-identity 
    allow-access-from-identity元素根据加密凭据授予权限,而 allow-access-from 则截然不同,它根据来源授予权限。
  • allow-http-request-headers-from 
    allow-http-request-headers-from元素用于授权发出请求的域中的请求文档将用户定义的标头发送到目标域。而 allow-access-from 元素旨在授权从目标域提取数据。这个标签授权以标头的形式推送数据。 
    属性: 
    • domain:指定要授予访问权限的的域。可以是域名,也可以是IP地址,子域将被视为不同的域。通配符 (*) 单独使用时可用于表示所有域,在用作以句点 (.) 分隔的明确二级域名前缀时表示多个域。表示单个域时需要使用单独的 allow-access-from 元素。
    • headers:以逗号分隔的标头列表,表示允许发送的请求域。通配符 (*) 可用于准许所有标头或头后缀,从而支持以相同字符开头但以不同字符结尾的标头。
    • secure:只适用于HTTPS,如果设置为 false,则表示允许 HTTPS 策略文件授权访问 HTTP 源发出的请求。默认值为 true,表示仅提供 HTTPS 源权限。我们不推荐使用 false。

三、匹配规则

  • 各个域或子域必须完全匹配。如www.example.com匹配http://www.example.com
  • IP地址和域名不匹配,即使IP地址就是域名指代的IP也不行。
  • 域通配符与该域本身及所有子域匹配。
  • 单独使用通配符 (*) 允许所有请求者进行访问,但不推荐使用。只有在策略文件范围内的所有内容完全公开的情况下才应当使用允许所有权限。

举例:

域值 匹配 不匹配
www.example.com http://www.example.com http://example.com 
http://example.com 
http://www.example.net
*.example.com http://example.com 
http://www.example.com 
http://deep.subdomain.example.com
http://www.example.net
http://*.example.com http://example.com 
http://www.example.com 
http://deep.subdomain.example.com
所有的https域
127.0.0.1 http://127.0.0.1 http://localhost 
http://127.0.0 
http://127.0.0.2
www.example.* 无效的值,不匹配

示例文件

<?xml version="1.0"?>   
<!DOCTYPE cross-domain-policy SYSTEM "http://www.adobe.com/xml/dtds/cross-domain-policy.dtd">
<cross-domain-policy>
    <site-control permitted-cross-domain-policies="master-only"/>
    <!-- 允许example.com及其子域访问 -->
    <allow-access-from domain="*.example.com"/>
    <!-- 允许http://www.example.com访问 -->
    <allow-access-from domain="www.example.com"/>
    <allow-http-request-headers-from domain="*.csdn.net" headers="*"/>
</cross-domain-policy>
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/houbin0912/article/details/81944471

智能推荐

Java中构造函数、set/get方法和toString方法的使用及注意事项_望穿秋水见伊人的博客-程序员秘密

一、构造函数构造函数的最大作用就是创建对象时完成初始化,当我们在new一个对象并传入参数的时候,会自动调用构造函数并完成参数的初始化。如下:public class Test01 { private String name; //有参构造函数 public Test01(String name) { this.name = name; } p...

《第一行代码Android》笔记九:MainActivity不是抽象的,并且未覆盖OnClickListener中的抽象方法onClick(查看)_错误: mainactivity不是抽象的, 并且未覆盖onclicklistener中的抽象方法o_JiandaoStudio的博客-程序员秘密

错误:(15,8)错误:MainActivity不是抽象的,并且未覆盖OnClickListener中的抽象方法onClick(查看)在练习书本实例时,出现以上错误,实例代码如下: 1 2 3 4 五 6 7 8 9 10 11 12 13 14 15 16 ...

vm.$set的使用_xiaocuizao的博客-程序员秘密

当我们写组件的路由时,我们知道在beforeRouterEnter这个路由钩子里(指的是当我们进入路由前),通常在这个钩子里面进行数据请求(准备阶段),这个时候我们是获取不到这个this的(在组件内this指代的就是这个组件),但是有时候我们需要通过this进行设置解决方案: beforeRouteEnter ( to,from,next ) { // console.log('bef...

python找不到模块pyodbc_ModuleNotFoundError:将pyodbc导入py scrip时没有名为“pyodbc”的模块..._weixin_39654751的博客-程序员秘密

我已经编写了一个简短的python脚本,它试图导入pyodbc扩展包,以便访问SQL表。import pyodbc as pyodbccnxn = pyodbc.connect('Driver={SQL Server};''Server=DESKTOP-UO8KJOP;''Database=ExamplePFData''Trusted_Connection=yes;')我已经使用:pip inst...

jquery动态生成的元素自动执行一次click事件_jq 自动点击某一元素_caixiajia的博客-程序员秘密

$(document).ready(function(){ $(".d").live("click",function(){ alert("自动点击链接被点击!"); }); $("#x").append("自动点击!");; $(".d").click(); });注意使用live绑定,动态生成的对象生成之后再执行click

在title上添加logo_如何在title中加logo_meishaonvhahaha的博客-程序员秘密

&lt;head&gt; &lt;meta charset="UTF-8"&gt; &lt;meta name="viewport" content="width=device-width, initial-scale=1,maximum-scale=1, user-scalable=no"&gt; &lt;title&gt;若初&lt;/title&gt; &l...

随便推点

Web_HONEY_NO_1的博客-程序员秘密

十问Web网站项目发表于2015-03-20 09:32| 1595次阅读| 来源CSDN| 0 条评论| 作者Richa JainWeb开发者设计用户体验优化摘要:Web设计和开发是一个长期的、迭代的过程。在一个Web项目开始前,我们应该有一个问题清单来帮助我们走完这一过程。虽然不断寻求改善是一件好事,但是更重要的是要务实,以及清楚地知道什么时候该停下完善的脚

windows 10放大125%后字体模糊 如何设置_帅气蟹老板的博客-程序员秘密

之前也被这个问题困扰着,查了很多方法,大部分都是下载一个dpi软件,虽然是一劳永逸的方法,但终究存在或多或少的问题。经过不懈努力,终于在某个网站发现了一个系统设置的方法,不需要下载任何软件,只需要更改系统的某个参数。 ——题记话不多说,直接上操作:1、按下Win+R组合键(运行),输入regedit,打开注册表编辑器;2、定位至HKEY_CURRENT_USER\Co...

SQL server数据库的操作步骤·图形界面工具_sql图形化界面_拎观的博客-程序员秘密

简介:一个SQL server数据库至少包括主数据文件和事务日志文件即以.mdf 、.ldf为扩展名的数据文件和日志文件。在SQL server系统中,通常有两种方式创建数据库:一种是使用图形界面工具,另一种是使用Transact-SQL语句。这里将介绍使用图形界面工具来创建数据库、基本表、数据库关系图及视图。目录创建数据库创建基本表创建数据库关系图录入数据创建视图创建数据库数据库是按照数据结构来组织、存储和管理数据的仓库,是所有数据库对象的承载。打开SQL ser...

C programe (The first day of the training of cognizant )_cprograme_陈勇士的博客-程序员秘密

homework 3#include#include#includeint Max(int[] ,int );int Min(int[] ,int );void disOdd(int[],int);void disEven(int[],int);int max,min,i;void main(){ clrscr(); int ar

阿里Druid连接池配置_canfengli的博客-程序员秘密

1.启用Druid连接池1.基于Maven配置如下(Gradle类似),pom.xml引入如下依赖: com.alibaba druid ${druid-version} 2.配置数据库连接 <bean id="dataSource" class="com.lianqian.urs.util.UrsDruidDataSource" d

推荐文章

热门文章

相关标签