九游平台/ 对象存储服务 obs/ sdk参考/ / / 设置跨域规则
更新时间:2024-12-09 gmt 08:00

设置跨域规则-九游平台

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

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

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

代码示例如下所示:

// 初始化配置参数
obsconfig config = new obsconfig();
config.endpoint = "https://your-endpoint";
// 认证用的ak和sk硬编码到代码中或者明文存储都有很大的安全风险,建议在配置文件或者环境变量中密文存放,使用时解密,确保安全;本示例以ak和sk保存在环境变量中为例,运行本示例前请先在本地环境中设置环境变量accesskeyid和secretaccesskey。
// 您可以登录访问管理控制台获取访问密钥ak/sk,获取方式请参见https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html
string accesskey= environment.getenvironmentvariable("accesskeyid", environmentvariabletarget.machine);
string secretkey= environment.getenvironmentvariable("secretaccesskey", environmentvariabletarget.machine);
// 创建obsclient实例
obsclient client = new obsclient(accesskey, secretkey, config);
// 设置桶跨域规则
try
{
    setbucketcorsrequest request = new setbucketcorsrequest();
    request.bucketname = "bucketname";
    request.configuration = new corsconfiguration();
    corsrule rule = new corsrule();
    rule.id = "20170820";
    // 指定允许跨域请求的来源
    rule.allowedorigins.add("http://www.a.com");
    rule.allowedorigins.add("http://www.b.com");
    // 控制在options预取指令中access-control-request-headers头中指定的header是否被允许使用
    rule.allowedheaders.add("x-obs-header");
    // 指定允许的跨域请求方法(get/put/delete/post/head)
    rule.allowedmethods.add(httpverb.head);
    rule.allowedmethods.add(httpverb.put);
    rule.allowedmethods.add(httpverb.get);
    rule.allowedmethods.add(httpverb.post);
    rule.allowedmethods.add(httpverb.delete);
    // 指定允许用户从应用程序中访问的header
    rule.exposeheaders.add("x-obs-test1");
    rule.exposeheaders.add("x-obs-test2");
    rule.maxageseconds = 100;
    request.configuration.rules.add(rule);
    setbucketcorsresponse response = client.setbucketcors(request);
    console.writeline("set bucket cors response: {0}", response.statuscode);
}
catch (obsexception ex)
{
    console.writeline("errorcode: {0}", ex.errorcode);
    console.writeline("errormessage: {0}", ex.errormessage);
}
  • allowedorigins、allowedmethods、allowedheaders都能够最多支持一个“*”通配符。“*”表示对于所有的域来源、操作或者头域都满足。

相关文档

网站地图