更新时间:2025-02-26 gmt 08:00

设置跨域规则-九游平台

开发过程中,您有任何问题可以在github上,或者在中发帖求助。详细介绍了每个接口的参数和使用方法。

您可以通过obsclient.setbucketcors设置桶的跨域规则,如果原规则存在则覆盖原规则。

本示例用于设置桶名为“bucketname”的跨域规则。

代码示例如下所示:

// 认证用的ak和sk硬编码到代码中或者明文存储都有很大的安全风险,建议在配置文件或者环境变量中密文存放,使用时解密,确保安全;本示例以ak和sk保存在环境变量中为例,运行本示例前请先在本地环境中设置环境变量access_key_id和secret_access_key_id。
// 您可以登录访问管理控制台获取访问密钥ak/sk,获取方式请参见https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html
string ak = system.getenv("access_key_id");
string sk = system.getenv("secret_access_key_id");
string endpoint = "https://your-endpoint";
// 创建obsclient实例
obsclient obsclient = new obsclient(ak, sk, endpoint);
bucketcors cors = new bucketcors();
list rules = new arraylist();
bucketcorsrule rule = new bucketcorsrule();
arraylist allowedorigin = new arraylist();
// 指定允许跨域请求的来源
allowedorigin.add( "http://www.a.com"); 
allowedorigin.add( "http://www.b.com"); 
rule.setallowedorigin(allowedorigin);
arraylist allowedmethod = new arraylist();
// 指定允许的跨域请求方法(get/put/delete/post/head)
allowedmethod.add("get");   
allowedmethod.add("head");
allowedmethod.add("put");   
rule.setallowedmethod(allowedmethod);
arraylist allowedheader = new arraylist();
// 控制在options预取指令中access-control-request-headers头中指定的header是否被允许使用
allowedheader.add("x-obs-header"); 
rule.setallowedheader(allowedheader);
arraylist exposeheader = new arraylist();
// 指定允许用户从应用程序中访问的header
exposeheader.add("x-obs-expose-header");
rule.setexposeheader(exposeheader);
// 指定浏览器对特定资源的预取(options)请求返回结果的缓存时间,单位为秒
rule.setmaxagesecond(10);
rules.add(rule);
cors.setrules(rules);
obsclient.setbucketcors("bucketname", cors);
  • allowedorigins、allowedheaders都能够最多支持一个“*”通配符。“*”表示对于所有的域来源或者头域都满足。

相关文档

网站地图