苏飞论坛

 找回密码
 马上注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

分布式系统框架(V1.3) 轻松承载百亿数据,千万流量!讨论专区 - 源码下载 - 官方教程

HttpHelper万能框架(V2.3-含.netcore) HttpHelper官方出品,无敌框架讨论区 - 源码下载 - 在线测试和代码生成

HttpHelper爬虫类(V2.0) 最牛的爬虫类,没有爬不到只有想不到 源码 - 代码生成器 - 讨论区 - 教程- 例子

查看: 32314|回复: 16

[教程] 解码,还原URL(URLDecode)/转码、编码URL(URLEncode)

[复制链接]
发表于 2014-9-10 08:38:24 | 显示全部楼层 |阅读模式
导读部分

【HttpHelper万能框架】教程目录贴  http://www.sufeinet.com/thread-9989-1-1.html


教程部分


我们在做登录时经常会碰到中文用户名,不可以登录,英文用户名可以登录的情况。
这种情况我们只需要将Url参数转码就可以了。
方法也很简单看下面代码
[C#] 纯文本查看 复制代码
  string parameters = "a=123456&b=456789&c=456456";
            //使用指定的编码对象对 URL 字符串进行编码。
            string URLEncode = HttpHelper.URLEncode(parameters);


            //使用指定的编码对象将 URL 编码的字符串转换为已解码的字符串。
            string URLDecode = HttpHelper.URLDecode(URLEncode);


            Response.Write(string.Format("<br/><br/>URLEncode={0}<br/>URLDecode={1}<br/>", URLEncode, URLDecode));


            //使用指定的编码对象对 URL 字符串进行编码。
            URLEncode = HttpHelper.URLEncode(parameters, System.Text.Encoding.UTF8);


            //使用指定的编码对象将 URL 编码的字符串转换为已解码的字符串。
            URLDecode = HttpHelper.URLDecode(URLEncode, System.Text.Encoding.UTF8);

            Response.Write(string.Format("<br/><br/>URLEncode={0}<br/>URLDecode={1}<br/>", URLEncode, URLDecode));


运行结果
[C#] 纯文本查看 复制代码
URLEncode=a%3d123456%26b%3d456789%26c%3d456456
URLDecode=a=123456&b=456789&c=456456


URLEncode=a%3d123456%26b%3d456789%26c%3d456456
URLDecode=a=123456&b=456789&c=456456


下面是一个例子大家一起来看看
比如我们要获取 淘宝的店铺信息

http://member1.taobao.com/member/user_profile.jhtml?user_id= hanwei
http://member1.taobao.com/member/user_profile.jhtml?user_id= 欧影点点

如果我们直接请求上面两个链接。第一个是可以正常返回数据的,但是第二个就不行了,因为出现的中文需要我们转化才可以。

使用万能框架代码如下
[C#] 纯文本查看 复制代码
            //创建Httphelper对象
            HttpHelper http = new HttpHelper();
            string url = "http://member1.taobao.com/member/user_profile.jhtml?user_id="+HttpHelper.URLEncode("欧影点点");
            //创建Httphelper参数对象
            HttpItem item = new HttpItem()
            {
                URL =url,//URL     必需项    
                Method = "get",//URL     可选项 默认为Get   
                ContentType = "text/html",//返回类型    可选项有默认值   
            };
            //请求的返回值对象
            HttpResult result = http.GetHtml(item);
            //获取请请求的Html
            string html = result.Html;
            //获取请求的Cookie
            string cookie = result.Cookie;

发表于 2014-9-12 13:44:30 | 显示全部楼层
发表于 2014-10-17 09:57:41 | 显示全部楼层
发表于 2014-11-14 20:53:34 | 显示全部楼层
发表于 2015-1-5 08:39:11 | 显示全部楼层
azon 发表于 2014-11-14 20:53
实例代码测试结果为:
无效的 URI: 未能确定 URI 的格式。

我的测试结果和你的一样。
发表于 2015-1-5 08:45:21 | 显示全部楼层
 楼主| 发表于 2015-1-5 09:01:42 | 显示全部楼层
发表于 2015-1-5 09:50:13 | 显示全部楼层
站长苏飞 发表于 2015-1-5 09:01
http://member1.taobao.com/member/user_profile.jhtml?user_id=这部分不转码就行了

哦。谢谢了。
发表于 2016-12-1 22:47:34 | 显示全部楼层
从留言的几个帖子来看,能否改进下,使整个URL能智能识别中文,完成转码,而不需要单独把中文转码在合并?
 楼主| 发表于 2016-12-2 08:20:53 | 显示全部楼层
super_vip 发表于 2016-12-1 22:47
从留言的几个帖子来看,能否改进下,使整个URL能智能识别中文,完成转码,而不需要单独把中文转码在合并?

转码是相对的,大部是不需要的 。另外有些地方是不允许转的。所以预期写死,不如果让用户使用更灵活
您需要登录后才可以回帖 登录 | 马上注册

本版积分规则

QQ|手机版|小黑屋|手机版|联系我们|关于我们|广告合作|苏飞论坛 ( 豫ICP备17001017号-1)

GMT+8, 2019-10-21 18:02

© 2017-2018

快速回复 返回顶部 返回列表