介绍:
我正在评估一个 asp.net Web 项目应用。它有一些可扩展性问题。意味着当网站访问量增加的时候。系统将会变得缓慢。当我查看应用日志。我找到了大量的ThreadAbortException. 这个应用大量的使用了Response.Redirect(是的 endResponse= true),这个就是可扩展性问题的根源。通过endResponse = false在Response.Redirect将会解决这个问题. 但这样做会导致应用程序出现一些奇怪的问题。因为应用程序将假设在Response.Redirect 将在当前页面停止执行.除此之外你需要处理一些安全隐患,因为你的应用程序是假设页面事件永远不会执行重定向之后。在这篇文章中,我将讲述一个简单的方法来解决这些问题,并取得良好性能
说明:
比方说你有一个web表单,需要验证一些条件并在条件不符时重定向用户跳转。
123456789101112 | 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扩展方法。
123456789101112131415161718192021222324252627282930313233 | 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.<span id=" 6_nwp " style=" width: auto; height: auto; float : none; "><a id=" 6_nwl " href=" http: //cpro.baidu.com/cpro/ui/uijs.php?adclass=0&app_id=0&c=news&cf=1001&ch=0&di=128&fv=18&is_app=0&jk=281390770ff04e69&k=asp&k0=asp&kdi0=0&luki=4&n=10&p=baidu&q=06011078_cpr&rb=0&rs=1&seller_id=1&sid=694ef00f77901328&ssp2=1&stid=0&t=tpclicked3_hc&tu=u1922429&u=http%3A%2F%2Fwww%2Eadmin10000%2Ecom%2Fdocument%2F3189%2Ehtml&urlid=0" target="_blank" mpid="6" style="text-decoration: none;"><span style="color:#0000ff;font-size:14px;width:auto;height:auto;float:none;">asp</span></a></span>x");
}
}
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检查,
12345678 | < form id = "form1" xml |