參考了網絡大部分的解決方案,沒一個能搞定的,如果窮途末路,試試下面的方法:
將獲得的前一頁面的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屬性了,所以就會拋出一個異常