跨域资源共享(Cross-origin resource sharing,简称CORS)允许Web端的应用程序访问不属于本域的资源。OSS提供跨域资源共享接口,方便您控制跨域访问的权限。
设置跨域资源共享规则
以下代码用于设置目标存储空间examplebucket的跨域资源共享规则。
<?php if (is_file(__DIR__ . '/../autoload.php')) { require_once __DIR__ . '/../autoload.php'; } if (is_file(__DIR__ . '/../vendor/autoload.php')) { require_once __DIR__ . '/../vendor/autoload.php'; } use OSS\OssClient; use OSS\Core\OssException; use OSS\Model\CorsConfig; use OSS\Model\CorsRule; // 阿里云账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM用户进行API访问或日常运维,请登录RAM控制台创建RAM用户。 $accessKeyId = "yourAccessKeyId"; $accessKeySecret = "yourAccessKeySecret"; // yourEndpoint填写Bucket所在地域对应的Endpoint。以华东1(杭州)为例,Endpoint填写为https://oss-cn-hangzhou.aliyuncs.com。 $endpoint = "yourEndpoint"; // 填写Bucket名称。 $bucket= "examplebucket"; $corsConfig = new CorsConfig(); $rule = new CorsRule(); // 设置允许跨域请求的响应头。AllowedHeader可以设置多个,每个AllowedHeader中最多只能使用一个通配符星号(*)。 // 建议无特殊需求时设置AllowedHeader为星号(*)。 $rule->addAllowedHeader("*"); // 设置允许用户从应用程序中访问的响应头。ExposeHeader可以设置多个,ExposeHeader中不支持使用通配符星号(*)。 $rule->addExposeHeader("x-oss-header"); // 设置允许的跨域请求的来源。AllowedOrigin可以设置多个,每个AllowedOrigin中最多只能使用一个通配符星号(*)。 $rule->addAllowedOrigin("https://example.com:8080"); $rule->addAllowedOrigin("https://*.aliyun.com"); // 设置AllowedOrigin为星号(*)时,表示允许所有域的来源。 //$rule->addAllowedOrigin("*"); // 设置允许的跨域请求方法。 $rule->addAllowedMethod("POST"); // 设置浏览器对特定资源的预取(OPTIONS)请求返回结果的缓存时间,单位为秒。 $rule->setMaxAgeSeconds(10); // 每个Bucket最多支持添加10条规则。 $corsConfig->addRule($rule); try{ $ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint); // 已存在的规则将被覆盖。 $ossClient->putBucketCors($bucket, $corsConfig); } catch(OssException $e) { printf(__FUNCTION__ . ": FAILED\n"); printf($e->getMessage() . "\n"); return; } print(__FUNCTION__ . ": OK" . "\n");
获取跨域资源共享规则
以下代码用于获取目标存储空间examplebucket的跨域资源共享规则。
<?php if (is_file(__DIR__ . '/../autoload.php')) { require_once __DIR__ . '/../autoload.php'; } if (is_file(__DIR__ . '/../vendor/autoload.php')) { require_once __DIR__ . '/../vendor/autoload.php'; } use OSS\OssClient; use OSS\Core\OssException; // 阿里云账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM用户进行API访问或日常运维,请登录RAM控制台创建RAM用户。 $accessKeyId = "yourAccessKeyId"; $accessKeySecret = "yourAccessKeySecret"; // yourEndpoint填写Bucket所在地域对应的Endpoint。以华东1(杭州)为例,Endpoint填写为https://oss-cn-hangzhou.aliyuncs.com。 $endpoint = "yourEndpoint"; // 填写Bucket名称。 $bucket= "examplebucket"; $corsConfig = null; try{ $ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint); $corsConfig = $ossClient->getBucketCors($bucket); } catch(OssException $e) { printf(__FUNCTION__ . ": FAILED\n"); printf($e->getMessage() . "\n"); return; } print(__FUNCTION__ . ": OK" . "\n"); print($corsConfig->serializeToXml() . "\n");
删除跨域资源共享规则
以下代码用于删除目标存储空间examplebucket的所有跨域资源共享规则。
<?php if (is_file(__DIR__ . '/../autoload.php')) { require_once __DIR__ . '/../autoload.php'; } if (is_file(__DIR__ . '/../vendor/autoload.php')) { require_once __DIR__ . '/../vendor/autoload.php'; } use OSS\OssClient; use OSS\Core\OssException; // 阿里云账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM用户进行API访问或日常运维,请登录RAM控制台创建RAM用户。 $accessKeyId = "yourAccessKeyId"; $accessKeySecret = "yourAccessKeySecret"; // yourEndpoint填写Bucket所在地域对应的Endpoint。以华东1(杭州)为例,Endpoint填写为https://oss-cn-hangzhou.aliyuncs.com。 $endpoint = "yourEndpoint"; // 填写Bucket名称。 $bucket= "examplebucket"; try{ $ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint); $ossClient->deleteBucketCors($bucket); } catch(OssException $e) { printf(__FUNCTION__ . ": FAILED\n"); printf($e->getMessage() . "\n"); return; } print(__FUNCTION__ . ": OK" . "\n");