更新时间: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); }];
父主题:
相关文档
意见反馈
文档内容是否对您有帮助?
提交成功!非常感谢您的反馈,我们会继续努力做到更好!
您可在查看反馈及问题处理状态。
系统繁忙,请稍后重试
如您有其它疑问,您也可以通过华为云社区问答频道来与我们联系探讨