C#获取URL参数值

摘要:
假设这个URL不是通过请求进来的,我们是没有办法通过Request来获取URL的参数值的,我们是否可以通过一个字符串stringurl="http://www.google.com/page?而且很多时候我们的URL的参数都是经过UrlEncode编码的,这个编码通常来说会是Encoding.UTF8或者Encoding.GetEncoding,需要提醒你的是:Baidu的URL是使用gb2312的,而Google是使用UTF8的。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=";Uriuri=newUri;stringqueryString=uri.Query;NameValueCollectioncol=GetQueryString;stringsearchKey=col["q"];//结果searchKey="博汇数码"}//////将查询字符串解析转换为名值集合./////////publicstaticNameValueCollectionGetQueryString{returnGetQueryString;}//////将查询字符串解析转换为名值集合.///////////////publicstaticNameValueCollectionGetQueryString{queryString=queryString.Replace("?

在写程序的时候,我们经常需要对页面进行传参数,比如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>publicvoidTest()
{
stringpageURL="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=";
Uriuri
=newUri(pageURL);
stringqueryString=uri.Query;
NameValueCollectioncol
=GetQueryString(queryString);
stringsearchKey=col["q"];
//结果searchKey="博汇数码"}
///<summary>///将查询字符串解析转换为名值集合.
///</summary>///<paramname="queryString"></param>///<returns></returns>publicstaticNameValueCollectionGetQueryString(stringqueryString)
{
returnGetQueryString(queryString,null,true);
}
///<summary>///将查询字符串解析转换为名值集合.
///</summary>///<paramname="queryString"></param>///<paramname="encoding"></param>///<paramname="isEncoded"></param>///<returns></returns>publicstaticNameValueCollectionGetQueryString(stringqueryString,Encodingencoding,boolisEncoded)
{
queryString
=queryString.Replace("?","");
NameValueCollectionresult
=newNameValueCollection(StringComparer.OrdinalIgnoreCase);
if(!string.IsNullOrEmpty(queryString))
{
intcount=queryString.Length;
for(inti=0;i<count;i++)
{
intstartIndex=i;
intindex=-1;
while(i<count)
{
charitem=queryString[i];
if(item=='=')
{
if(index<0)
{
index
=i;
}
}
elseif(item=='&')
{
break;
}
i
++;
}
stringkey=null;
stringvalue=null;
if(index>=0)
{
key
=queryString.Substring(startIndex,index-startIndex);
value
=queryString.Substring(index+1,(i-index)-1);
}
else
{
key
=queryString.Substring(startIndex,i-startIndex);
}
if(isEncoded)
{
result[MyUrlDeCode(key,encoding)]
=MyUrlDeCode(value,encoding);
}
else
{
result[key]
=value;
}
if((i==(count-1))&&(queryString[i]=='&'))
{
result[key]
=string.Empty;
}
}
}
returnresult;
}
///<summary>///解码URL.
///</summary>///<paramname="encoding">null为自动选择编码</param>///<paramname="str"></param>///<returns></returns>publicstaticstringMyUrlDeCode(stringstr,Encodingencoding)
{
if(encoding==null)
{
Encodingutf8
=Encoding.UTF8;
//首先用utf-8进行解码stringcode=HttpUtility.UrlDecode(str.ToUpper(),utf8);
//将已经解码的字符再次进行编码.stringencode=HttpUtility.UrlEncode(code,utf8).ToUpper();
if(str==encode)
encoding
=Encoding.UTF8;
else
encoding
=Encoding.GetEncoding("gb2312");
}
returnHttpUtility.UrlDecode(str,encoding);
}
复制代码

说明

  1. 对于下面的编码方式中,Baidu是使用gb2312,而Google是使用UTF8的,所以这些编码如何解释呢?解决办法就是如MyUrlDeCode方法所写的,把编码进行一次解码,再把解码后的字符串进行编码,再对字符串进行比较,如果是相同的,那就是使用了这种编码的。还要注意进行ToUpper字符串。
  2. //博汇数码.stringbaidu=HttpUtility.UrlDecode("wd=%B2%A9%BB%E3%CA%FD%C2%EB");
    stringgoogle=HttpUtility.UrlDecode("q=%E5%8D%9A%E6%B1%87%E6%95%B0%E7%A0%81");
  3. 关于returnGetQueryString(queryString,null,true);如果你传入的是null,那就是表示你无法确认编码是gb2312还是UTF8,当你确认编码的,可以直接传入编码类型,比如returnGetQueryString(queryString,Encoding.UTF8,true);
  4. 需要注意queryString=queryString.Replace("?","");把?给过滤掉。
  5. %B2%A9%BB%E3%CA%FD%C2%EB =%B2%A9 %BB%E3 %CA%FD %C2%EB(博汇数码gb2312)
  6. %E5%8D%9A%E6%B1%87%E6%95%B0%E7%A0%81 =%E5%8D%9A %E6%B1%87 %E6%95%B0 %E7%A0%81(博汇数码utf-8)

-------------------华丽分割线-------------------

作者:听风吹雨

免责声明:文章转载自《C#获取URL参数值》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇多数据源切换-Druidrabbitmq进阶下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

日常编码规范(Java版)

规范: 命名: 接口命名。接口必须是名词,并且接口是能准确的描述要做的事情,命名能清晰的看出输入输出,可以是抽象的行为描述。接口必须以一个动作的名词形式结尾,比如reader,handler等。接口的命名,必须是抽象的,除非接口本身和具体实现紧密相关,否则不应该在接口中包含任何和具体实现相关的名词。接口命名根据行为分为以下几种: 读取某个数据,命名: {...

微信小程序http接口封装怎么实现

微信小程序http接口封装怎么实现?微信小程序开发的编写,需要调用后端接口,经常要用到wx.request方法,所以就自己封装了一下,简化一下代码,如果能给大家提供帮助更好,我的项目后端是使用的Java SSM框架,wx.request的URL就是后端提供的接口。在封装的时候我在网上看了很多篇博客,90%以上的全都是直接在success回调函数中直接打印返...

SpringBoot整合升级Spring Security 报错 【The request was rejected because the URL was not normalized】

前言 最近LZ给项目框架升级, 从Spring1.x升级到Spring2.x, 在这里就不多赘述两个版本之间的区别以及升级的原因。 关于升级过程中踩的坑,在其他博文中会做比较详细的记录,以便给读者参考,不要掉进同样的坑里。 这里我们讨论一个关于URL中包含双斜杠被拦截的问题。 发现问题 升级框架之后,测试一个功能时,发现报错Http 500, 第一时间怀疑...

9.2.4 .net core 通过ViewComponent封装控件

我们在.net core中还使用了ViewComponent方式生成控件。ViewComponent也是asp.net core的新特性,是对页面部分的渲染,以前PartialView的功能,可以使用ViewComponent来实现。 View Component包含2个部分,一个是类(继承于ViewComponent),和它返回的结果Razor视图(和...

HTML中几个常见的问题

一、HTML中几个常见的问题  1.div图片img与div容器下有距离的解决办法   这个问题经常出现在网站的布局,也是前端面试官作为浏览器兼容性经常提起的“老标兵”。   出现状况:IE6,IE7下的img与div(块元素)会出现一些间隔,IE7才会有这个问题,IE8下是没有的。   出现原因:图片和文字等行内元素默认是和父级元素的baseline(b...

java web 拦截器、过滤器理解

1、首先要明确什么是拦截器、什么是过滤器 1.1 什么是拦截器: 拦截器,在AOP(Aspect-Oriented Programming)中用于在某个方法或字段被访问之前,进行拦截然后在之前或之后加入某些操作。拦截是AOP的一种实现策略。 在Webwork的中文文档的解释为——拦截器是动态拦截Action调用的对象。它提供了一种机制可以使开发者可以...