高效的使用 Response.Redirect解决一些不必要的问题
程序员文章站
2024-02-23 12:20:28
介绍: 我正在评估一个 asp.net web 项目应用。它有一些可扩展性问题。意味着当网站访问量增加的时候。系统将会变得缓慢。当我查看应用日志。我找到了大量的 threa...
介绍:
我正在评估一个 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优化和技术以降低风险 .也同样希望你喜欢这篇文章。
我正在评估一个 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优化和技术以降低风险 .也同样希望你喜欢这篇文章。
推荐阅读
-
高效的使用 Response.Redirect解决一些不必要的问题
-
使用MySQL Slow Log来解决MySQL CPU占用高的问题
-
如何解决一些项目开发和维护中的问题——Hibernate实战篇 博客分类: hibernate Hibernate项目管理SpringSQLDAO
-
使用LengthFieldBasedFrameDecoder解决复杂的自定义协议-粘包与半包问题
-
如何解决一些项目开发和维护中的问题——Hibernate实战篇 博客分类: hibernate Hibernate项目管理SpringSQLDAO
-
java接口中私有方法定义和使用(解决代码重复的问题)
-
使用MySQL Slow Log来解决MySQL CPU占用高的问题
-
关于vue-awesome-swiper使用遇到的一些问题和心得(手动设置宽、手机翻转问题、回调函数、滑动)
-
PHP使用PDO操作数据库的乱码问题解决方法,pdo乱码
-
PHP的foreach中使用引用时需要注意的一个问题和解决方法_PHP教程