全部產品
Search
文件中心

CDN:重寫訪問URL

更新時間:Nov 27, 2025

如果來源站點資源路徑變化,CDN節點資源路徑也會變化。使用者請求的URL路徑不變時,CDN節點需要重寫請求的URL,將其重新導向到目標路徑,以減少回源並提升用戶端訪問效能。

背景資訊

HTTP 302狀態代碼(302 Found)表示資源臨時改變位置。配置訪問URL重寫後,CDN節點會在HTTP Location頭部放置新的URL,用戶端收到302響應後會請求新的URL。

配置訪問URL重寫規則後,CDN節點預設發送302狀態代碼,同時也支援303和307狀態代碼,如果您需要修改狀態代碼,可以通過提交工單申請。

編碼

含義

處理方法

典型應用情境

302

Found

GET方法不會發生變更,其他方法有可能會變更為GET方法。

由於不可預見的原因該頁面暫不可用。在這種情況下,搜尋引擎不會更新它們的連結。

303

See Other

GET方法不會發生變更,其他方法會變更為 GET 方法(訊息主體會丟失)。

用於PUT或POST請求完成之後進行頁面跳轉,防止由於頁面重新整理導致的操作的重複觸發。

307

Temporary Redirect

方法和訊息主體都不發生變化。

由於不可預見的原因該頁面暫不可用。在這種情況下,搜尋引擎不會更新它們的連結。當網站支援非 GET 方法的連結或操作的時候,該狀態代碼優於 302 狀態代碼。

重要

單個網域名稱最多可以配置50條重寫規則。配置多條規則時,按照CDN控制台訪問URL重寫列表由上而下的順序執行。

重寫訪問URL和重寫回源URL的區別

功能

作用對象

用戶端體驗

應用情境

重寫訪問URL

影響的是用戶端訪問的URL,同時也會改變CDN節點回源的URL。

  • 執行規則為 redirect 的情況下,用戶端將會使用重新導向以後的URL重新發起訪問請求。

  • 執行規則為 break 的情況下,用戶端看到的URL與實際訪問的URL一致,沒有變化。

常用於將舊網域名稱的URL遷移、映射到新網域名稱;或者為移動端和PC端提供不同的URL。

樣本:訪問old.example.com/hello時,重寫訪問URL為new.example.com/hello

重寫回源URL

影響的是CDN節點回源時訪問的URL,而用戶端訪問的URL不變。

用戶端看到的URL與實際訪問的URL一致,沒有變化。

常用於隱藏來源站點的真實URL結構,保護來源站點資訊;或者通過URL映射,讓CDN節點回源到不同的來源站點目錄。

樣本:訪問cdn.example.com/hello時重寫回源URL為origin.example.com/source/hello

重寫訪問URL示意圖

  1. 用戶端向CDN發起請求,請求的URL為old.example.com/hello

  2. CDN接收到請求後,根據重寫訪問URL規則,CDN節點會在給用戶端發送的302狀態代碼響應資訊的HTTP Location頭部中放置新的URL地址資訊,將請求的URL重寫為new.example.com/hello

  3. 用戶端收到302狀態代碼響應之後,將會向新的URL地址發起請求。

  4. CDN節點檢查緩衝,如果緩衝中有重寫後URL的內容,直接返回給用戶端;如果沒有,則CDN節點向來源站點發起請求,請求的URL為重寫後的new.example.com/hello

  5. 來源站點接收到請求,返迴響應內容給CDN節點。

  6. CDN節點將響應內容緩衝,並返回給用戶端。

重寫回源URL示意圖

  1. 用戶端向CDN發起請求,請求的URL為cdn.example.com/files/hello.txt

  2. CDN接收到請求後,檢查緩衝,如果緩衝中有請求URL的內容,直接返回給用戶端;如果沒有,則CDN節點根據重寫回源URL規則,將回源URL重寫為 origin.example.com/secret/files/hello.txt,向來源站點發起請求。

  3. 來源站點接收到請求後,向CDN節點返迴響應內容。

  4. CDN節點將響應內容緩衝,並返回給用戶端。

操作步驟

  1. 登入CDN控制台

  2. 在左側導覽列,單擊域名管理

  3. 域名管理頁面,找到目標網域名稱,單擊操作列的管理

  4. 在指定網域名稱的左側導覽列,單擊缓存配置

  5. 單擊重寫訪問URL頁簽。

  6. 單擊添加,根據您的實際需求,配置訪問URL重寫參數。

    image

    參數

    說明

    待重寫的Path

    僅支援以/開頭的Path,不含協議頭和網域名稱;支援PCRERegex,如 ^/hello$

    目標Path

    • 執行規則設定為Break的情況下,僅支援以/開頭的Path,不含協議頭和網域名稱。

    • 執行規則設定為Redirect的情況下,可以包含協議頭和網域名稱。支援PCRERegex,例如:常用$1$2來捕獲待改寫Path中圓括弧內的字串。

    执行规则

    • 預設支援RedirectBreak這兩種規則。

      • Redirect:如果請求URL匹配了某條規則,該請求將會被302重新導向到目標URL,節點返回給用戶端的Location資訊為目標URL(不修改原始URL中的參數)。執行完當前規則後,當存在其他配置規則時,會繼續匹配剩餘規則。

      • Break:如果請求URL匹配了某條規則,該請求將會被重寫為目標URL(不修改原始URL中的參數)。執行完當前規則後,當存在其他配置規則時,將不再匹配剩餘規則。

    • 同時支援enhance-breakenhance_redirect三種規則,這三種規則需要提交工單申請後台配置。

      • : 配置了多條規則的情況下,如果請求URL匹配了某條規則,執行完當前規則以後,還會繼續匹配後續規則。

      • enhance_break : 和 break類似,但是會修改包含參數在內的整個URL。

      • enhance_redirect : 和redirect類似,但是會修改包含參數在內的整個URL。

    說明

    不同的執行規則使用的重寫方式不同,重寫後的URL是否支援其他網域名稱、其他協議也存在差異:

    • Breakenhance_break採用直接重寫使用者請求URL的方式,不支援重寫為其他網域名稱,也不支援重寫為其他協議(例如從HTTP協議重寫為HTTPS協議)。

    • Redirectenhance_redirect採用302跳轉方式實現URL重寫,支援重寫為其他網域名稱,也支援重寫為其他協議:

      • 302 Location地址除了可以設定為當前的加速網域名稱,還支援設定為其他網域名稱,可以實現這樣的效果:原始URL使用的網域名稱是example.com,重寫後的URL使用新的網域名稱aliyundoc.com

      • 302 Location地址支援使用其他協議,可以實現這樣的效果:原始URL使用HTTP協議,重寫後的URL使用HTTPS協議。

    規則條件

    規則條件能夠對使用者請求中攜帶的各種參數資訊進行識別,以此來決定某個配置是否對該請求生效。

    • 不使用:不使用規則條件。

    • 若需新增或編輯規則條件,請在規則引擎中進行管理。

    開啟Nginx變數計算

    預設為不勾選,勾選後可以在目標URL中使用Nginx內建變數。配置樣本如下:

    • 待重寫的Path:^/test.jpg$

    • 目標Path:/test.${arg_type}

    • 開啟Nginx變數計算以後實現的效果是會把${nginx_var}值計算出來,${arg_type}表示原始URL中參數type的值。

    說明

    該參數需提交工單申請後台配置。

  7. 單擊確定,完成配置。

    成功配置重寫功能後,您可以在重寫列表中,對當前的配置進行修改刪除操作。

配置樣本

【樣本1】

用戶端請求http://example.aliyundoc.com/hello時,請求中包含/helloCDN節點會在302狀態代碼的Location資訊裡寫入新的URL地址http://example.aliyundoc.com/index.html,並返回給用戶端,用戶端對http://example.aliyundoc.com/index.html發起請求。

正則表達

說明

用戶端在302重新導向的時候,如果Location中不包含協議頭和網域名稱,那麼會預設使用原始請求的協議頭和網域名稱。

【樣本2】

用戶端請求http://example.aliyundoc.com/hello時,請求中包含/hello,匹配上了Regex^/hello$CDN節點會給用戶端響應302狀態代碼,並且在Location資訊裡寫入目標URL https://test.aliyundoc.com/index.html,用戶端收到響應之後,將會對https://test.aliyundoc.com/index.html發起請求。

image

【樣本3】

用戶端請求http://www.example.com/cdn/url/http://image.example.com/image/cat.jpg時,請求中包含/cdn/url/http://,匹配上了Regex^/cdn/url/http://(.*)CDN節點會給用戶端響應302狀態代碼,並且在Location資訊裡寫入目標URL http://image.example.com/image/cat.jpg,用戶端收到響應之後,將會對http://image.example.com/image/cat.jpg發起請求。

image