更新时间:2025-02-26 gmt 08:00
设置跨域规则-j9九游会登录
开发过程中,您有任何问题可以在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都能够最多支持一个“*”通配符。“*”表示对于所有的域来源或者头域都满足。
父主题:
相关文档
意见反馈
文档内容是否对您有帮助?
提交成功!非常感谢您的反馈,我们会继续努力做到更好!
您可在查看反馈及问题处理状态。
系统繁忙,请稍后重试
如您有其它疑问,您也可以通过华为云社区问答频道来与我们联系探讨