将获得的前一页面的URL分成两段,后面的参数部分进行编码(直接对URL编码是不行的),然后再组合一下就可以了,需要的朋友可以了解下
将获得的前一页面的URL分成两段,后面的参数部分进行编码(直接对URL编码是不行的),然后再组合一下就可以了。 
if(!Page.IsPostBack) { ReUrl = Page.Request.UrlReferrer.ToString().Split('?')[0].ToString() + HttpUtility.UrlEncode(Page.Request.UrlReferrer.Query,System.Text.Encoding.GetEncoding("GB2312")); if (ReUrl == null || ReUrl == "") { ReUrl = HttpContext.Current.Request.Url.PathAndQuery ; } ViewState["ReUrl"] = ReUrl; }
另外注意点的是,返回到前一页时需要进行解码 
Response.Redirect(Server.UrlDecode((string)ViewState[“ReUrl”].ToString())); 
在参考解决方案发现了一段比较重要的代码,特别是对于安全性较高的网站来说可能有的作用。 
1,在用户改变地址栏的URL的参数的时候,提示用户无权执行此操作 
把下面代码放在Page_Load事件里 
try { string strTemp = Request.UrlReferrer.PathAndQuery ; } catch { throw new Exception("你不能修改参数!") ; }
说明:此方法属于”偏门”方法,利用的是,如果用户修改URL的参数,Request.UrlReferrer 
将会得到null,null当然不可能有PathAndQuery属性了,所以就会抛出一个异常