ASP.NET中擷取URL重寫前的原始地址

來源:互聯網
上載者:User

  在ASP.NET中,如果你使用了URL重寫,通過HttpContext.Request擷取到的是重寫後的地址。如果這個地址要返回給用戶端(比如Redirect),我們一般希望是重寫前的友好地址。

  通常的使用情境是當我們有某個頁面需要使用者登入才能訪問時,我們會在代碼中判斷當前訪問使用者是否登入,如果未登入,則重新導向至登入頁面,並將當前網址通過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"]);
}

  題外話:

  ISAPI_Rewrite與IIS的URL Rewrite模組有個很小的區別,卻給從ISAPI_Rewrite遷移至URL Rewrite帶來了很大麻煩。比如:對於http://www.cnblogs.com/cmt/這個網址,ISAPI_Rewrite是用“/cmt/”進行匹配,而URL Rewrite模組卻用“cmt/”進行匹配,相差一個斜杠,卻造成遷移時要修改在ISAPI_Rewrite中寫的每一條Regex。而且,URL Rewrite還提供了從ISAPI_Rewrite匯入規則的功能,卻沒有考慮這種情況。

  祝大家元旦快樂!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.