原文:C#獲取URL參數值
在寫程序的時候,我們經常需要對頁面進行傳參數,比如page?id=1234,那么在page這個頁面中就直接可以使用string id = Request.QueryString["id"]; 來獲取參數id的值1234了。這是一個人人都知道的基礎知識。
上面的方法:Request.QueryString,它會把傳入的URL進行分析,並把結果保存在一個鍵值(key value)的Collection中,我們只要通過設置key值,就可以返回這個key所對應的value了。
假設這個URL不是通過請求進來的,我們是沒有辦法通過Request來獲取URL的參數值的,我們是否可以通過一個字符串string url = "http://www.google.com/page?id=1234"中分析出Collection[key]=value呢?而且很多時候我們的URL的參數都是經過UrlEncode編碼的,這個編碼通常來說會是Encoding.UTF8或者Encoding.GetEncoding("gb2312"),需要提醒你的是:Baidu的URL是使用gb2312的,而Google是使用UTF8的。那對於傳入的字符串我們如何確認是該使用gb2312還是UTF8來解碼呢?
在Baidu或者Google搜索到相關的解決辦法中,你會看到這樣的說法,那就是通過正則表達式去匹配URL,例如:Regex urlRegex = new Regex(@"(?:^|\?|&)courseid=(\d*)(?:&|$)"); 但是我比較懷疑通過這個方法分析出來的數據完整性,它有辦法確保匹配出所有數據嗎?后來我想到了模擬Microsoft .NET Framework中Request的方法來解決這個問題。其實上面的string id = Request.QueryString["id"];
也可以寫成 System.Collections.Specialized.NameValueCollection col = Request.QueryString; string strID = col[”id”];所以讓我們來構造這個NameValueCollection吧!
/// <summary> /// 測試. /// </summary> public void Test() { string pageURL = "http://www.google.com.hk/search?hl=zh-CN&source=hp&q=%E5%8D%9A%E6%B1%87%E6%95%B0%E7%A0%81&aq=f&aqi=g2&aql=&oq=&gs_rfai="; Uri uri = new Uri(pageURL);// 在這里用的Uri這個,如果直接打印出來uri,會將source后面的編碼解密出來:"博匯數碼" string queryString = uri.Query; NameValueCollection col = GetQueryString(queryString); string searchKey = col["q"]; //結果 searchKey = "博匯數碼" }
/// <summary> /// 解碼URL. /// </summary> /// <param name="encoding">null為自動選擇編碼</param> /// <param name="str"></param> /// <returns></returns> public static string MyUrlDeCode(string str, Encoding encoding) { if (encoding == null) { Encoding utf8 = Encoding.UTF8; //首先用utf-8進行解碼 string code = HttpUtility.UrlDecode(str.ToUpper(), utf8); //將已經解碼的字符再次進行編碼. string encode = HttpUtility.UrlEncode(code, utf8).ToUpper(); if (str == encode) encoding = Encoding.UTF8; else encoding = Encoding.GetEncoding("gb2312"); } return HttpUtility.UrlDecode(str, encoding); }