更新时间:2024-12-09 GMT+08:00
设置跨域规则
您可以通过ObsClient.SetBucketCors设置桶的跨域规则,如果原规则存在则覆盖原规则。
本示例用于设置桶名为“bucketname”的跨域规则。
代码示例如下所示:
// 初始化配置参数
ObsConfig config = new ObsConfig();
config.Endpoint = "https://your-endpoint";
// 认证用的ak和sk硬编码到代码中或者明文存储都有很大的安全风险,建议在配置文件或者环境变量中密文存放,使用时解密,确保安全;本示例以ak和sk保存在环境变量中为例,运行本示例前请先在本地环境中设置环境变量AccessKeyID和SecretAccessKey。
// 您可以登录访问管理控制台获取访问密钥AK/SK,获取方式请参见https://support.huaweicloud.com/intl/zh-cn/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都能够最多支持一个“*”通配符。“*”表示对于所有的域来源、操作或者头域都满足。
父主题: 跨域资源共享