热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

ASP.NET中c#的URL编码处理

ASP.NET中c#的URL编码处理今天一个朋友叫我给改这个传参中文乱码问题.要解决的问题:将下面的URL作为一个参数传到其他的页面1http:domainde.apx?ui
ASP.NET中c#的URL编码处理

今天一个朋友叫我给改这个传参中文乱码问题....要解决的问题:
将下面的URL作为一个参数传到其他的页面
1 http://domain/de.apx?uid=12&page=15
2 url后面的参数中出现汉字等,如: ....aspx?title=起重机
在出现上面的情况的时候,必须经过一个RUL编码和解码的过程,否则会出现错误.
代码如下:
复制内容到剪贴板代码:

一解

//传值
string temp = " 添加到收藏夹");


//在另外一个文件中取从上面传的值
if (Request.QueryString["url"] != null)
            {
                string url = Server.UrlDecode(Request.QueryString["url"].ToString());
                this.txtAddress.Text = url;
            }
            if (Request.QueryString["title"] != null)
            {
               string title = Server.UrlDecode(Request.QueryString["title"].ToString());
                this.txtTitle.Text = title;
           }
二解

加:
ASP.NET中c#的URL编码处理System.Web.HttpUtility.UrlEncode(StrDept, System.Text.Encoding.Default)

三解: 
urlDecode()

asp解:
request.QueryString("xmlText")


1、COOKIE存放的目录

COOKIE是存放在客户端的东东,放在“TemporaryInternetFiles”目录,所以说存在安全性的问题。大伙可通过以下方式找到 具体位置:打开控制面板→Internet选项→常规→Internet临时文件→设置→即可看到“当前位置”,→点击“查看文件”将直接打开该文件夹, 你也可以点击“移动文件夹”变更它所在的位置。

2、COOKIE的有效期

从上图我们可以清楚的看到每个COOKIE文档的“截止期”(即为有效期)。在有效期内,当登录计算机的用户Administrator再次访问 172.meibu.com时,那么IE就会在请求页面的同时,连同上述的名称为 “COOKIE:administrator@172.meibu.com”的COOKIE文档内容一起发送给服务器。

若该文档包含多个COOKIE的值时,截止期则以最后的失效期为准。

3、COOKIE的类型

这里我们按有效期来分,分为两种:

a)即时型

指的是关闭浏览器(所有浏览172.meibu.com的IE)后,COOKIE便失效,此类COOKIE不会在“TemporaryInternetFiles”目录出现。其实它也有截止期的,为“0001-01-01”

b)持久型

就是已指定具体“截止期”的,能够在“TemporaryInternetFiles”目录里面找到的COOKIE

4、COOKIE的内容

双击打开“COOKIE:administrator@172.meibu.com”,我们看到以下内容,如下图(http://blog.csdn.net/images/blog_csdn_net/cityhunter172/85935/r_aspxForm06.jpg):

上图中,“■”是换行符,你若是要打破什么锅来问我到底是怎么知道的话。我倒是会很乐意的告诉你:这就是经验!偶从学习C#那刻起,就拿第一个Windows程序——记事本来开刀,保存文档时得来的经验。

所以服务器读出来的格式如下图(http://blog.csdn.net/images/blog_csdn_net/cityhunter172/85935/r_aspxForm07.jpg):

5、在ASP.NET页面发放COOKIE

发送上述COOKIE的.cs代码为:

System.Web.HttpCOOKIE ck=new HttpCOOKIE("ckValue0");

ck["Author"]="CityHunter";

ck.Expires=System.DateTime.Now.AddMinutes(10);//若不指定,则为即时型COOKIE

//ck.Path="/FormTest/ManageSys";//设置COOKIE的虚拟路径,注意一定要以“/”开头,否则为无效COOKIE;请大家自行看一下它与在客房端的COOKIE文档“名称”与“Internet地址”的关系

Response.COOKIEs.Add(ck);

 

ck=newHttpCOOKIE("ckValue1");//重新新建一个名为ckValue1的COOKIE

ck.Expires=System.DateTime.Now.AddMinutes(20);//即刻起20分钟后失效

ck["E_Mail"]="cityhunter172@126.com";//设置ckValue1中的E_Mail值

ck["PersonalWeb"]="172.meibu.com";

Response.COOKIEs.Add(ck);//添加此COOKIE

6、取回已发放COOKIE的值

Response.Write(Request.COOKIEs["ckValue0"]["Author"]+"
");//用不着说明了吧

Response.Write(Request.COOKIEs["ckValue1"]["E_Mail"]+"
");

Response.Write(Request.COOKIEs["ckValue1"]["PersonalWeb"]);

好久没有出作业啦(何出此言?),这第三篇呀,可是花了偶两个星期的业余时间调试、总结、撰写哪,都说时光贵如金,不知我花的这些时间能换来多少银子?换银子,我看是没指望啦,能得到阁下的一句评论,偶也满足了。记住,你的评论就是偶继续写下去的动力。

作业:给COOKIE赋于以下值,怎样得到它的正确值

ck["str1"]="2222";

ck["str"]="str0=11111&str1=223";

可以肯定的是Request.COOKIEs["ckValue1"]["str"]得不到“str0=11111&str1=223”这个字串,大家不妨试一下Request.COOKIEs["ckValue1"]["str1"]会得到意想不到的字串哟。

提示:使用Server.UrlEncode()与Server.UrlDecode()

十三、发放永久性的验证COOKIE

终于……终于……最后一个章节,蓦然回首,洋洋洒洒十二章。没想到年少时写不完作文的偶,居然也能编出几千余字的文章来呀,不得不佩服偶自己呀!再回首,一大片晕倒的人……。永远到底有多远?永久究竟是多久?只有天知道。

大家登录CSDN的时候是否留意到一个“2周内不用再登录”的复选框,它又是怎么做到的呢?大家是否曾遇到过这样的困惑:在执行 System.Web.Security.FormsAuthentication.SetAuthCOOKIE时明明已指定 createPersistentCOOKIE为true为何关闭浏览器仍不能直接访问网站?下面我们就这个问题给大家解释一下,且介绍如何手工创建身份 验证票并加入COOKIE中。

System.Web.Security.FormsAuthenticationTicket tk=newSystem.Web.Security.FormsAuthenticationTicket(

1,//指定版本号:可随意指定

"Admin",//登录用户名:对应Web.config中的users属性

System.DateTime.Now,//发布时间

System.DateTime.Now.AddYears(100),//失效时间:100年以后,够永够久了吧

false,//是否为持久COOKIE:尚未发现有何用,至少目前偶还不知,下面会有说明

"测试用户数据"//用户数据:可用((System.Web.Security.FormsIdentity)User.Identity).Ticket.UserData获取

);

stringstr=System.Web.Security.FormsAuthentication.Encrypt(tk);//加密身份验票

 

//声明一个COOKIE,名称为Web.config中的name属性,对应的值为身份验票加密后的字串

System.Web.HttpCOOKIEck=newHttpCOOKIE(System.Web.Security.FormsAuthentication.FormsCOOKIEName,str);

 

//指定COOKIE为Web.config中path属性,不指定则默认为“/”

ck.Path=System.Web.Security.FormsAuthentication.FormsCOOKIEPath;

//此句非常重要,少了的话,就算此COOKIE在身份验票中指定为持久性COOKIE,也只是即时型的COOKIE关闭浏览器后就失效;因此上面我说:我是真的还不知在身份验票中指定为持久性COOKIE有何用。

ck.Expires=System.DateTime.Now.AddYears(100);

Response.COOKIEs.Add(ck);//添加至客房端



推荐阅读
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • ASP.NET2.0数据教程之十四:使用FormView的模板
    本文介绍了在ASP.NET 2.0中使用FormView控件来实现自定义的显示外观,与GridView和DetailsView不同,FormView使用模板来呈现,可以实现不规则的外观呈现。同时还介绍了TemplateField的用法和FormView与DetailsView的区别。 ... [详细]
  • 单点登录原理及实现方案详解
    本文详细介绍了单点登录的原理及实现方案,其中包括共享Session的方式,以及基于Redis的Session共享方案。同时,还分享了作者在应用环境中所遇到的问题和经验,希望对读者有所帮助。 ... [详细]
  • 本文介绍了绕过WAF的XSS检测机制的方法,包括确定payload结构、测试和混淆。同时提出了一种构建XSS payload的方法,该payload与安全机制使用的正则表达式不匹配。通过清理用户输入、转义输出、使用文档对象模型(DOM)接收器和源、实施适当的跨域资源共享(CORS)策略和其他安全策略,可以有效阻止XSS漏洞。但是,WAF或自定义过滤器仍然被广泛使用来增加安全性。本文的方法可以绕过这种安全机制,构建与正则表达式不匹配的XSS payload。 ... [详细]
  • Apache Shiro 身份验证绕过漏洞 (CVE202011989) 详细解析及防范措施
    本文详细解析了Apache Shiro 身份验证绕过漏洞 (CVE202011989) 的原理和影响,并提供了相应的防范措施。Apache Shiro 是一个强大且易用的Java安全框架,常用于执行身份验证、授权、密码和会话管理。在Apache Shiro 1.5.3之前的版本中,与Spring控制器一起使用时,存在特制请求可能导致身份验证绕过的漏洞。本文还介绍了该漏洞的具体细节,并给出了防范该漏洞的建议措施。 ... [详细]
  • Jquery 跨域问题
    为什么80%的码农都做不了架构师?JQuery1.2后getJSON方法支持跨域读取json数据,原理是利用一个叫做jsonp的概念。当然 ... [详细]
  • adfs是什么_培训与开发的概念
    adfs是什么_培训与开发的概念(如您转载本文,必须标明本文作者及出处。如有任何疑问请与我联系me@nap7.com)ADFS相关开发技术的中文资料相对匮乏,之前在弄这个东西的时候 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • 本文讨论了如何使用Web.Config进行自定义配置节的配置转换。作者提到,他将msbuild设置为详细模式,但转换却忽略了带有替换转换的自定义部分的存在。 ... [详细]
  • JavaScript和HTML之间的交互是经由过程事宜完成的。事宜:文档或浏览器窗口中发作的一些特定的交互霎时。能够运用侦听器(或处置惩罚递次来预订事宜),以便事宜发作时实行相应的 ... [详细]
  • .NetCoreWebApi生成Swagger接口文档的使用方法
    本文介绍了使用.NetCoreWebApi生成Swagger接口文档的方法,并详细说明了Swagger的定义和功能。通过使用Swagger,可以实现接口和服务的可视化,方便测试人员进行接口测试。同时,还提供了Github链接和具体的步骤,包括创建WebApi工程、引入swagger的包、配置XML文档文件和跨域处理。通过本文,读者可以了解到如何使用Swagger生成接口文档,并加深对Swagger的理解。 ... [详细]
  • 本文讨论了在ASP中创建RazorFunctions.cshtml文件时出现的问题,即ASP.global_asax不存在于命名空间ASP中。文章提供了解决该问题的代码示例,并详细解释了代码中涉及的关键概念,如HttpContext、Request和RouteData等。通过阅读本文,读者可以了解如何解决该问题并理解相关的ASP概念。 ... [详细]
  • 初探PLC 的ST 语言转换成C++ 的方法
    自动控制软件绕不开ST(StructureText)语言。它是IEC61131-3标准中唯一的一个高级语言。目前,大多数PLC产品支持ST ... [详细]
author-avatar
幽咽小香
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有