通常的使用場景是當我們有某個頁面需要用戶登錄才能訪問時,我們會在代碼中判斷當前訪問用戶是否登錄,如果未登錄,則重定向至登錄頁面,並將當 前網址通過Url參數傳遞給登錄頁面。如果使用了URL重寫,並通過Request.Url.AbsoluteUri獲取當前網址,用戶登錄後打開的就是 重寫後的地址,這雖然不影響正常使用,但從用戶體驗及URL統一的角度,我們更希望是重寫前的地址。
之前,我們在開發中也被這個問題困擾,只能盡量通過js重定向至登錄頁面(通過location.href獲取當前網址)或者在代碼中手動寫返回地址。
現在,我們找到了解決方法,可以從Request.Headers中找到重寫前的網址。
1)如果重寫組件用的是ISAPI_Rewrite,則訪問被重寫的網址時,Headers中會增加一項數據:Key為X-Rewrite-URL,值為重寫前的網址。
2)如果重寫組件用的是IIS自帶的URL Rewrite模塊,則Headers中增加的信息的Key為X-Original-URL。
這樣我們就可以輕松獲取重寫前的網址,示例代碼如下:
復制代碼 代碼如下:
if (Request.Headers["X-Rewrite-URL"] != null)
{
Response.Write("http://" + Request.Url.Host + Request.Headers["X-Rewrite-URL"]);
}
else if (Request.Headers["X-Original-URL"] != null)
{
Response.Write("http://" + Request.Url.Host + Request.Headers["X-Original-URL"]);
}