更新时间:2023-11-08 gmt 08:00

设置跨域规则-九游平台

您可以通过setbucketcors设置桶的跨域规则,如果原规则存在则覆盖原规则。以下代码展示了如何设置跨域规则:

static obsclient *client;
nsstring *endpoint = @"your-endpoint";
// 认证用的ak和sk硬编码到代码中或者明文存储都有很大的安全风险,建议在配置文件或者环境变量中密文存放,使用时解密,确保安全;本示例以ak和sk保存在环境变量中为例,运行本示例前请先在本地环境中设置环境变量accesskeyid和secretaccesskey。
// 您可以登录访问管理控制台获取访问密钥ak/sk,获取方式请参见https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html
char* ak_env = getenv("accesskeyid");
char* sk_env = getenv("secretaccesskey");
nsstring *ak = [nsstring stringwithutf8string:ak_env];
nsstring *sk = [nsstring stringwithutf8string:sk_env];
    
// 初始化身份验证
obsstaticcredentialprovider *credentialprovider = [[obsstaticcredentialprovider alloc] initwithaccesskey:ak secretkey:sk];
    
 //初始化服务配置
obsserviceconfiguration *conf = [[obsserviceconfiguration alloc] initwithurlstring:endpoint credentialprovider:credentialprovider];
    
// 初始化client
client = [[obsclient alloc] initwithconfiguration:conf];
    
// 设置桶的跨域资源共享
    
obssetbucketcorsrequest *request = [[obssetbucketcorsrequest alloc] initwithbucketname:@"bucketname"];
obscorsrule* rule = [obscorsrule new];
// 指定允许的跨域请求方法(get/put/delete/post/head)
rule.allowedmethodlist = @[obscorshttpget,obscorshttpput,obscorshttppost,obscorshttphead];
// 指定允许跨域请求的来源
rule.allowedoriginlist = @[@"www.example1.com",@"www.example2.com"];
// 允许的header
rule.allowedheaderlist = @[@"allowedheader1",@"allowedheader2"];
// 指定允许用户从应用程序中访问的header
rule.exposeheaderlist = @[@"exposeheader_1",@"exposeheader_2"];
// 指定浏览器对特定资源的预取(options)请求返回结果的缓存时间,单位为秒
rule.maxageseconds = [nsnumber numberwithint:100];
[request.bucketcorsrulelist addobject:rule];
[client setbucketcors:request completionhandler:^(obssetbucketcorsresponse *response, nserror *error) {
    nslog(@"%@",response);
 }];

相关文档

网站地图