您可以將儲存空間(Bucket)設定為靜態網站託管模式並設定鏡像回源的跳轉規則(RoutingRule)。靜態網站託管模式配置生效後,訪問網站相當於訪問Bucket,並且能夠自動跳轉至指定的索引頁面和錯誤頁面。鏡像回源的跳轉規則配置生效後,可用於資料無縫遷移到OSS的情境。
注意事項
本文範例程式碼以華東1(杭州)的地區ID
cn-hangzhou為例,預設使用外網Endpoint,如果您希望通過與OSS同地區的其他阿里雲產品訪問OSS,請使用內網Endpoint。關於OSS支援的Region與Endpoint的對應關係,請參見OSS地區和訪問網域名稱。本文以從環境變數讀取存取憑證為例。如何配置訪問憑證,請參見配置訪問憑證。
要設定靜態網站託管或者鏡像回源,您必須有
oss:PutBucketWebsite許可權;要擷取靜態網站託管或者鏡像回源,您必須有oss:GetBucketWebsite許可權;要刪除靜態網站託管或者鏡像回源,您必須有oss:DeleteBucketWebsite許可權。具體操作,請參見為RAM使用者授予自訂的權限原則。
靜態網站託管
靜態網站是指所有的網頁都由靜態內容構成,包括用戶端執行的指令碼(例如JavaScript)。您可以通過靜態網站託管功能將您的靜態網站託管到Bucket,並使用Bucket的訪問網域名稱訪問這個網站。
設定靜態網站託管
以下代碼用於設定靜態網站託管:
package main
import (
"context"
"flag"
"log"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss/credentials"
)
// 定義全域變數
var (
region string // 儲存地區
bucketName string // 儲存空間名稱
)
// init函數用於初始化命令列參數
func init() {
flag.StringVar(®ion, "region", "", "The region in which the bucket is located.")
flag.StringVar(&bucketName, "bucket", "", "The name of the bucket.")
}
func main() {
// 解析命令列參數
flag.Parse()
// 檢查bucket名稱是否為空白
if len(bucketName) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, bucket name required")
}
// 檢查region是否為空白
if len(region) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, region required")
}
// 載入預設配置並設定憑證提供者和地區
cfg := oss.LoadDefaultConfig().
WithCredentialsProvider(credentials.NewEnvironmentVariableCredentialsProvider()).
WithRegion(region)
// 建立OSS用戶端
client := oss.NewClient(cfg)
// 建立設定儲存空間靜態網站託管的請求
request := &oss.PutBucketWebsiteRequest{
Bucket: oss.Ptr(bucketName), // 儲存空間名稱
WebsiteConfiguration: &oss.WebsiteConfiguration{
IndexDocument: &oss.IndexDocument{
Suffix: oss.Ptr("index.html"), // 設定靜態網站託管的預設首頁為index.html
SupportSubDir: oss.Ptr(true), // 設定支援子目錄
Type: oss.Ptr(int64(0)), // 類型(0表示靜態網站)
},
ErrorDocument: &oss.ErrorDocument{
Key: oss.Ptr("error.html"), // 設定靜態網站託管的錯誤頁面為error.html
HttpStatus: oss.Ptr(int64(404)), // HTTP狀態代碼
},
},
}
// 執行設定儲存空間靜態網站託管的請求
result, err := client.PutBucketWebsite(context.TODO(), request)
if err != nil {
log.Fatalf("failed to put bucket website %v", err)
}
// 列印設定儲存空間靜態網站託管的結果
log.Printf("put bucket website result:%#v\n", result)
}
查看靜態網站託管配置
以下代碼用於查看靜態網站託管配置:
package main
import (
"context"
"flag"
"log"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss/credentials"
)
// 定義全域變數
var (
region string // 儲存地區
bucketName string // 儲存空間名稱
)
// init函數用於初始化命令列參數
func init() {
flag.StringVar(®ion, "region", "", "The region in which the bucket is located.")
flag.StringVar(&bucketName, "bucket", "", "The name of the bucket.")
}
func main() {
// 解析命令列參數
flag.Parse()
// 檢查bucket名稱是否為空白
if len(bucketName) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, bucket name required")
}
// 檢查region是否為空白
if len(region) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, region required")
}
// 載入預設配置並設定憑證提供者和地區
cfg := oss.LoadDefaultConfig().
WithCredentialsProvider(credentials.NewEnvironmentVariableCredentialsProvider()).
WithRegion(region)
// 建立OSS用戶端
client := oss.NewClient(cfg)
// 建立擷取儲存空間靜態網站配置的請求
request := &oss.GetBucketWebsiteRequest{
Bucket: oss.Ptr(bucketName), // 儲存空間名稱
}
// 執行擷取儲存空間靜態網站配置的操作並處理結果
result, err := client.GetBucketWebsite(context.TODO(), request)
if err != nil {
log.Fatalf("failed to get bucket website %v", err)
}
// 列印擷取儲存空間靜態網站配置的結果
log.Printf("get bucket website result:%#v\n", result)
}
刪除靜態網站託管配置
以下代碼用於刪除靜態網站託管配置:
package main
import (
"context"
"flag"
"log"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss/credentials"
)
// 定義全域變數
var (
region string // 儲存地區
bucketName string // 儲存空間名稱
)
// init函數用於初始化命令列參數
func init() {
flag.StringVar(®ion, "region", "", "The region in which the bucket is located.")
flag.StringVar(&bucketName, "bucket", "", "The name of the bucket.")
}
func main() {
// 解析命令列參數
flag.Parse()
// 檢查bucket名稱是否為空白
if len(bucketName) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, bucket name required")
}
// 檢查region是否為空白
if len(region) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, region required")
}
// 載入預設配置並設定憑證提供者和地區
cfg := oss.LoadDefaultConfig().
WithCredentialsProvider(credentials.NewEnvironmentVariableCredentialsProvider()).
WithRegion(region)
// 建立OSS用戶端
client := oss.NewClient(cfg)
// 建立刪除儲存空間靜態網站託管配置的請求
request := &oss.DeleteBucketWebsiteRequest{
Bucket: oss.Ptr(bucketName),
}
// 執行刪除儲存空間靜態網站託管配置的操作並處理結果
result, err := client.DeleteBucketWebsite(context.TODO(), request)
if err != nil {
log.Fatalf("failed to delete bucket website %v", err)
}
// 列印刪除儲存空間靜態網站託管配置的結果
log.Printf("delete bucket website result:%#v\n", result)
}
鏡像回源
鏡像回源主要用於資料無縫遷移到OSS的情境。例如某服務已經在使用者建立的來源站點或者在其他雲產品上運行,現因業務發展,需要將服務遷移至OSS,遷移時需保證服務的正常運行。您可以在遷移過程中使用鏡像回源規則擷取未遷移至OSS的部分資料,保證服務的正常運行。
設定鏡像回源
例如,當要求者訪問目標Bucket中不存在的檔案時,可以通過指定回源條件和回源地址,從來源站點中擷取目標檔案。例如您在華東1(杭州)有名為examplebucket的Bucket,您希望要求者訪問Bucket根目錄下examplefolder目錄中不存在的檔案時,可以從www.example.com網站的examplefolder目錄擷取目標檔案。
以下代碼用於設定符合上述情境的鏡像回源規則:
package main
import (
"context"
"flag"
"log"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss/credentials"
)
// 定義全域變數
var (
region string // 儲存地區
bucketName string // 儲存空間名稱
)
// init函數用於初始化命令列參數
func init() {
flag.StringVar(®ion, "region", "", "The region in which the bucket is located.")
flag.StringVar(&bucketName, "bucket", "", "The name of the bucket.")
}
func main() {
// 解析命令列參數
flag.Parse()
// 檢查bucket名稱是否為空白
if len(bucketName) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, bucket name required")
}
// 檢查region是否為空白
if len(region) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, region required")
}
// 載入預設配置並設定憑證提供者和地區
cfg := oss.LoadDefaultConfig().
WithCredentialsProvider(credentials.NewEnvironmentVariableCredentialsProvider()).
WithRegion(region)
// 建立OSS用戶端
client := oss.NewClient(cfg)
// 設定鏡像回源規則
ruleOk := oss.RoutingRule{
RuleNumber: oss.Ptr(int64(1)),
Condition: &oss.RoutingRuleCondition{
KeyPrefixEquals: oss.Ptr("myobject"), // 指定匹配對象首碼
HttpErrorCodeReturnedEquals: oss.Ptr(int64(404)), // 指定回源條件為HTTP狀態代碼404
},
Redirect: &oss.RoutingRuleRedirect{
RedirectType: oss.Ptr("Mirror"), // 指定重新導向類型為鏡像
MirrorURL: oss.Ptr("http://www.test.com/"), // 指定回源地址
MirrorHeaders: &oss.MirrorHeaders{
//PassAll: oss.Ptr(true), // 指定傳遞所有頭部
Passs: []string{"myheader-key1", "myheader-key2"}, // 允許傳遞指定HTTP Header參數
Removes: []string{"myheader-key3", "myheader-key4"}, // 禁止傳遞指定HTTP Header參數
Sets: []oss.MirrorHeadersSet{
{
Key: oss.Ptr("myheader-key5"), // 設定指定HTTP Header參數的名稱
Value: oss.Ptr("myheader-value"), // 設定指定HTTP Header參數的值
},
},
},
},
}
// 建立設定鏡像回源的請求
request := &oss.PutBucketWebsiteRequest{
Bucket: oss.Ptr(bucketName), // 儲存空間名稱
WebsiteConfiguration: &oss.WebsiteConfiguration{
IndexDocument: &oss.IndexDocument{
Suffix: oss.Ptr("index.html"), //設定鏡像回源的預設頁面為index.html
SupportSubDir: oss.Ptr(true),
Type: oss.Ptr(int64(0)),
},
ErrorDocument: &oss.ErrorDocument{
Key: oss.Ptr("error.html"), // 設定鏡像回源的錯誤頁面為error.html
HttpStatus: oss.Ptr(int64(404)),
},
RoutingRules: &oss.RoutingRules{
RoutingRules: []oss.RoutingRule{
ruleOk,
},
},
},
}
// 執行設定鏡像回源的請求
result, err := client.PutBucketWebsite(context.TODO(), request)
if err != nil {
log.Fatalf("failed to put bucket website %v", err)
}
// 列印設定鏡像回源的結果
log.Printf("put bucket website result:%#v\n", result)
}
擷取鏡像回源配置
以下代碼用於擷取鏡像回源配置:
package main
import (
"context"
"flag"
"log"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss/credentials"
)
// 定義全域變數
var (
region string // 儲存地區
bucketName string // 儲存空間名稱
)
// init函數用於初始化命令列參數
func init() {
flag.StringVar(®ion, "region", "", "The region in which the bucket is located.")
flag.StringVar(&bucketName, "bucket", "", "The name of the bucket.")
}
func main() {
// 解析命令列參數
flag.Parse()
// 檢查bucket名稱是否為空白
if len(bucketName) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, bucket name required")
}
// 檢查region是否為空白
if len(region) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, region required")
}
// 載入預設配置並設定憑證提供者和地區
cfg := oss.LoadDefaultConfig().
WithCredentialsProvider(credentials.NewEnvironmentVariableCredentialsProvider()).
WithRegion(region)
// 建立OSS用戶端
client := oss.NewClient(cfg)
// 建立擷取鏡像回源配置的請求
request := &oss.GetBucketWebsiteRequest{
Bucket: oss.Ptr(bucketName), // 儲存空間名稱
}
// 執行擷取鏡像回源配置的操作並處理結果
result, err := client.GetBucketWebsite(context.TODO(), request)
if err != nil {
log.Fatalf("failed to get bucket website %v", err)
}
// 列印擷取鏡像回源配置的結果
log.Printf("get bucket website result:%#v\n", result.WebsiteConfiguration.RoutingRules)
}
刪除鏡像回源配置
以下代碼用於刪除鏡像回源配置:
package main
import (
"context"
"flag"
"log"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss/credentials"
)
// 定義全域變數
var (
region string // 儲存地區
bucketName string // 儲存空間名稱
)
// init函數用於初始化命令列參數
func init() {
flag.StringVar(®ion, "region", "", "The region in which the bucket is located.")
flag.StringVar(&bucketName, "bucket", "", "The name of the bucket.")
}
func main() {
// 解析命令列參數
flag.Parse()
// 檢查bucket名稱是否為空白
if len(bucketName) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, bucket name required")
}
// 檢查region是否為空白
if len(region) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, region required")
}
// 載入預設配置並設定憑證提供者和地區
cfg := oss.LoadDefaultConfig().
WithCredentialsProvider(credentials.NewEnvironmentVariableCredentialsProvider()).
WithRegion(region)
// 建立OSS用戶端
client := oss.NewClient(cfg)
// 建立刪除鏡像回源配置的請求
request := &oss.DeleteBucketWebsiteRequest{
Bucket: oss.Ptr(bucketName),
}
// 執行刪除鏡像回源配置的操作並處理結果
result, err := client.DeleteBucketWebsite(context.TODO(), request)
if err != nil {
log.Fatalf("failed to delete bucket website %v", err)
}
// 列印刪除鏡像回源配置的結果
log.Printf("delete bucket website result:%#v\n", result)
}
相關文檔
關於靜態網站託管以及鏡像回源的完整範例程式碼,請參見put_bucket_website.go, get_bucket_website.go和delete_bucket_website.go。
關於設定靜態網站託管或者鏡像回源的API介面說明,請參見PutBucketWebsite。
關於擷取靜態網站託管或者鏡像回源的API介面說明,請參見GetBucketWebsite。
關於刪除靜態網站託管或者鏡像回源的API介面說明,請參見DeleteBucketWebsite。