国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

高效的使用 Response.Redirect

2019-11-17 01:25:53
字體:
來源:轉載
供稿:網友

高效的使用 Response.Redirect

  介紹:

  我正在評估一個 asp.net Web 項目應用。它有一些可擴展性問題。意味著當網站訪問量增加的時候。系統將會變得緩慢。當我查看應用日志。我找到了大量的ThreadAbortException. 這個應用大量的使用了Response.Redirect(是的 endResponse= true),這個就是可擴展性問題的根源。通過endResponse = false在Response.Redirect將會解決這個問題. 但這樣做會導致應用程序出現一些奇怪的問題。因為應用程序將假設在Response.Redirect 將在當前頁面停止執行.除此之外你需要處理一些安全隱患,因為你的應用程序是假設頁面事件永遠不會執行重定向之后。在這篇文章中,我將講述一個簡單的方法來解決這些問題,并取得良好性能

  說明:

  比方說你有一個web表單,需要驗證一些條件并在條件不符時重定向用戶跳轉。

PRotected void Page_Load(object sender, EventArgs e)        {            var condition = ......;            if (!condition)            {                Response.Redirect("SomePage.aspx");            }        }        protected void btnSave_Click(object sender, EventArgs e)        {            // Save Data Here        }

  這樣做很好,但這會影響可擴展性能。因為它將會終止線程池.現在,只需要用Response.Redirect("Unauthorized.aspx", false)替換Response.Redirect("Unauthorized.aspx"). 這將解決線程終止的問題,但不會停止當前頁面生命周期. 也就是說,你有需要確保 btnSave_Click事件(和所有其他頁面時間)因為只要允許btnSave_Click事件執行任何人都可以很容易地發送POST請求. 為了解決這個問題我推薦使用RedirectUser擴展方法。

public static class HttpResponseExtensions    {        public static void RedirectUser(this HttpResponse response, string url)        {            if (response.IsRequestBeingRedirected)                return;            response.Redirect(url, false);            var context = HttpContext.Current;            if (context != null)            {                context.applicationInstance.CompleteRequest();            }        }    }    public partial class WebForm : System.Web.UI.Page    {        protected void Page_Load(object sender, EventArgs e)        {            var condition = .....;            if (!condition)            {                Response.RedirectUser("Unauthorized.aspx");            }        }        protected void btnSave_Click(object sender, EventArgs e)        {            if (Response.IsRequestBeingRedirected)            {                return;            }            // Save Data Here        }    }

  使用RedirectUser 第一個好處是它將首先使用對于應用程序具有良好擴展性的Response.Redirect(with endResponse= false) 方法。.第二個好處就是在你多次調用這個方法后它不會覆蓋先前的Response.Redirect(如果有的話). 第三個好處是它會調用HttpApplication.CompleteRequest用來處理 ASP.NET運行時所有通過的事件以及過濾HTTP 管道信息(不是頁面生命周期管道信息).另外你需要注意在btnSave_Click事件中檢查Response.IsRequestBeingRedirected.我也希望你把所有的內部控制放到 Response.IsRequestBeingRedirected檢查,

<form id="form1" runat="server">        <% if(!Response.IsRequestBeingRedirected){ %>            <asp:Button ID="btnSave" runat="server" Text="Save" OnClick="btnSave_Click" />            <%--All the Other Controls--%>            <%--All the Other Controls--%>            <%--All the Other Controls--%>        <%} %>    </form>

  另一件你需要注意的事情,當你使用一個復雜的控制(類似GridView, RadGrid, etc)這些擁有 選擇,插入,更新和刪除事件時。當 Response.IsRequestBeingRedirected為true時,你必須取消操作(插入,更新或刪除) 這些事件,下面是一個例子

protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)        {            if (Response.IsRequestBeingRedirected)            {                e.Cancel = true;                return;            }        }

總結:

  在這篇文章里,我向您展示如何使用Response.Redirect . 我同樣也發現了一些風險問題。可以采用Response.Redirect優化和技術以降低風險 .也同樣希望你喜歡這篇文章。

  原文地址:http://weblogs.asp.net/imranbaloch/archive/2013/10/04/using-response-redirect-effectively.aspx


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 泸水县| 宁海县| 鄂托克旗| 黄骅市| 临邑县| 台东市| 溧水县| 巴中市| 永泰县| 庆元县| 金堂县| 乌鲁木齐市| 洪泽县| 夏河县| 镇江市| 虎林市| 仙游县| 鹿邑县| 长阳| 阿图什市| 珲春市| 连南| 梁山县| 陆丰市| 宁城县| 樟树市| 额尔古纳市| 洪泽县| 张家川| 晋宁县| 呼伦贝尔市| 华坪县| 辽宁省| 荣昌县| 怀柔区| 洛浦县| 邹平县| 上林县| 宁陵县| 仁怀市| 同心县|