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

小甜饼Cookie

Cookie似乎是每个接触过BS结构软件人都知道的东西,但是可能大多数人依然对其不太了解!关于Cookie的作用我就不多说了,其本质就是保

COOKIE似乎是每个接触过BS结构软件人都知道的东西,但是可能大多数人依然对其不太了解!
关于COOKIE的作用我就不多说了,其本质就是保存用户状态!它是保存在客户机端的一个小文本文件!
COOKIE的创建
在ASP.NET中创建COOKIE,可以在后台代码CS文件中创建。如下:

None.gif        private void SetCOOKIE(string COOKIEName,string COOKIEValue)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{
InBlock.gif            HttpCOOKIE COOKIE 
= new HttpCOOKIE(COOKIEName,COOKIEValue); //实例化一COOKIE对象
InBlock.gif
            Response.COOKIEs.Add(COOKIE);                                //将COOKIE输出到客户端
ExpandedBlockEnd.gif
        }
当然也可以通过Javascript创建!上面创建的方法其本质仍然是Javascript创建,如下:
None.gif        function setCOOKIE(COOKIEName,COOKIEValue)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{            
InBlock.gif            window.document.COOKIE    
= COOKIEName + "=" + escape(COOKIEValue)+";";
ExpandedSubBlockStart.gifContractedSubBlock.gif            
/**//*COOKIE中的值都是键值对的形式,一个键对应一个值!如上"COOKIEName=COOKIEValue"
InBlock.gif            创建一个名为COOKIEName 值为COOKIEValue的COOKIE,
InBlock.gif            加上escape函数是为了解决COOKIE值中有特殊字符将其编码!
InBlock.gif            当然,这样在读取的时候也相应需要unescape解码            
ExpandedSubBlockEnd.gif            
*/

ExpandedBlockEnd.gif        }
COOKIE的读取
上面是COOKIE的创建,读取相对也很容易!在ASP.NET中如下:
None.gif        private void ReadCOOKIE(string COOKIEName)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{
InBlock.gif            
if( Request.COOKIEs[COOKIEName] == null || Request.COOKIEs[COOKIEName].Value.ToString().Trim()=="")
InBlock.gif                Response.Write(
"COOKIE is not exist");
InBlock.gif            
else
InBlock.gif                Response.Write(Request.COOKIEs[COOKIEName].Value.ToString().Trim());
ExpandedBlockEnd.gif        }
在Javascript中如下:
None.gif        function read(COOKIEName)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{            
InBlock.gif            
var COOKIEString = document.COOKIE;    
InBlock.gif            
var start = COOKIEString.indexOf(COOKIEName + '=');
InBlock.gif            
InBlock.gif            
if (start == -1//若不存在该名字的COOKIE
InBlock.gif
                return null;
InBlock.gif            
InBlock.gif            start 
+= COOKIEName.length + 1;
InBlock.gif            
InBlock.gif            
var end = COOKIEString.indexOf(';', start);
InBlock.gif            
InBlock.gif            
if (end == -1//防止最后没有加“;”冒号的情况            
InBlock.gif
                return unescape(COOKIEString.substring(start));
InBlock.gif                
InBlock.gif            
return unescape(COOKIEString.substring(start, end));
ExpandedBlockEnd.gif        }
本质也就是字符串的截取
上面关于COOKIE为最基本的应用,但往往我们实际中像上面的应用并不能满足需求!
例如:假设我在http://localhost/TestCOOKIE/COOKIE/Default.aspx 这样的应用程序下用如上代码建立COOKIE,那么,当我重新打开浏览器并输入上述地址时,COOKIE的值即不存在!
这是为什么,COOKIE不是存在客户机端吗?为什么下次再打开IE即不存在,这其实为初学者常常不明白的问题。COOKIE有过期时间的问题,我们在设置COOKIE时,如果没有明确指定COOKIE的过期时间,那么COOKIE的默认过期时间即与浏览器关联,也即当我们关闭IE时,此COOKIE自动失效,这也就是为什么当我们征订打开浏览器时COOKIE不存在的原因!
因此有了上述认识,要解决这个问题即可以如下:在创建COOKIE时设置一个过期时间!
在ASP.NET中:
None.gif        private void SetCOOKIE(string COOKIEName,string COOKIEValue)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{
InBlock.gif            HttpCOOKIE COOKIE     
= new HttpCOOKIE("COOKIEName","COOKIEValue");
InBlock.gif
InBlock.gif            DateTime time         
= DateTime.Now;
InBlock.gif
InBlock.gif            TimeSpan timeAdd     
= new TimeSpan(0,0,30);//时间相隔30秒            
InBlock.gif

InBlock.gif            COOKIE.Expires         
= time.Add(timeAdd);    //设置COOKIE过期时间为30 秒
InBlock.gif
            
InBlock.gif            Response.COOKIEs.Add(COOKIE);
ExpandedBlockEnd.gif        }
在Javascript中
None.gif        function setCOOKIE(COOKIEName,COOKIEValue)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{    
InBlock.gif            
var dat=new Date();
InBlock.gif            dat.setTime(dat.getTime()
+365*24*3600*1000);//在当时时间上加365天        
InBlock.gif
            window.document.COOKIE    = COOKIEName + "=" + escape(COOKIEValue)+";expires="+ dat.toGMTString()+";";
ExpandedSubBlockStart.gifContractedSubBlock.gif            
/**//*            
InBlock.gif                在创建时指定了expires属性,即过期时间
ExpandedSubBlockEnd.gif            
*/

ExpandedBlockEnd.gif        }
这样当下次 我们再重新打开IE时,只要在COOKIE有效期内,都会存在!
如上,COOKIE的应用范围就变大了点!
但实际中往往还不能满足应用!如上:我是在http://localhost/TestCOOKIE/COOKIE/Default.aspx 页面创建的COOKIE,那么在http://localhost/TestCOOKIE/COOKIE/ 目录及COOKIE/ 子目录中所有的所有的页面都是可以访问到该COOKIE的。但现在假如我们需要在整个应用程序中读取如http://localhost/TestCOOKIE/ 在TestCOOKIE整个应用程序中读取,按如上方式来设置COOKIE是做不到的,这时我们需要指定可访问COOKIE的 路径。所以在创建时需要如下:
ASP.NET中
None.gif        private void SetCOOKIE(string COOKIEName,string COOKIEValue)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{
InBlock.gif            HttpCOOKIE COOKIE     
= new HttpCOOKIE("COOKIEName","COOKIEValue");
InBlock.gif
InBlock.gif            DateTime time         
= DateTime.Now;
InBlock.gif
InBlock.gif            TimeSpan timeAdd     
= new TimeSpan(0,0,30);//时间相隔30秒            
InBlock.gif

InBlock.gif            COOKIE.Expires         
= time.Add(timeAdd);    //设置COOKIE过期时间为30 秒
InBlock.gif
            
InBlock.gif            COOKIE.Path             
= "/COOKIE";            
ExpandedSubBlockStart.gifContractedSubBlock.gif            
/**//*设置可访问COOKIE的路径 为项目下的COOKIE文件夹及其子文件夹下所有页面
InBlock.gif             * 如果需要整个应用程序可访问 则设置为COOKIE.Path = "/";即可
ExpandedSubBlockEnd.gif             
*/

InBlock.gif            
InBlock.gif            Response.COOKIEs.Add(COOKIE);
ExpandedBlockEnd.gif        }
在Javascript中
None.gif        function setCOOKIE(COOKIEName,COOKIEValue)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{    
InBlock.gif            
var dat=new Date();
InBlock.gif            dat.setTime(dat.getTime()
+365*24*3600*1000);//在当时时间上加365天        
InBlock.gif
            window.document.COOKIE    = COOKIEName + "=" + escape(COOKIEValue)+";expires="+ dat.toGMTString()+";path=/;";
ExpandedSubBlockStart.gifContractedSubBlock.gif            
/**//*            
InBlock.gif                在创建时指定了path 属性,即可访问COOKIE的页面为整个应用程序内所有页面
ExpandedSubBlockEnd.gif            
*/

ExpandedBlockEnd.gif        }
这样COOKIE的可应用范围又增加了不少!
是不是就够了呢?还不,经常我们在网上会看到很大比较大的系统,都有二级域名,
如http://www.163.com 它有很多二级域名,如http://news.163.com 如果按上述方式来创建COOKIE,那么在http://www.163.com 创建的COOKIE 在http://news.163.com域名内是无法访问到的。这时我们在创建时应该指定可访问COOKIE的主机名,主机名是指在同一个域下的不同主机 ,默认情况下一个主机中创建的COOKIE是不能被另一个主机访问的,但可以在创建COOKIE时通过设置domain属性来修改。
如下:
在Asp.net中
None.gifprivate void SetCOOKIE(string COOKIEName,string COOKIEValue)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{
InBlock.gif            HttpCOOKIE COOKIE     
= new HttpCOOKIE("COOKIEName","COOKIEValue");
InBlock.gif
InBlock.gif            DateTime time         
= DateTime.Now;
InBlock.gif
InBlock.gif            TimeSpan timeAdd     
= new TimeSpan(0,0,30);//时间相隔30秒            
InBlock.gif

InBlock.gif            COOKIE.Expires         
= time.Add(timeAdd);    //设置COOKIE过期时间为30 秒
InBlock.gif
            
InBlock.gif            COOKIE.Path             
= "/COOKIE";            
ExpandedSubBlockStart.gifContractedSubBlock.gif            
/**//*设置可访问COOKIE的路径 为项目下的COOKIE文件夹及其子文件夹下所有页面
InBlock.gif             * 如果需要整个应用程序可访问 则设置为COOKIE.Path = "/";即可
ExpandedSubBlockEnd.gif             
*/

InBlock.gif            
InBlock.gif            COOKIE.Domain
=".163.com";
ExpandedSubBlockStart.gifContractedSubBlock.gif            
/**//*以www.163.com为例,若要在 news.163.com等不同主机访问可以如上设置*/
InBlock.gif            Response.COOKIEs.Add(COOKIE);
ExpandedBlockEnd.gif        }
在Javascript中
None.gif        function setCOOKIE(COOKIEName,COOKIEValue)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{    
InBlock.gif            
var dat=new Date();
InBlock.gif            dat.setTime(dat.getTime()
+365*24*3600*1000);//在当时时间上加365天        
InBlock.gif
            window.document.COOKIE    = COOKIEName + "=" + escape(COOKIEValue)+";expires="+ dat.toGMTString()+";path=/;domain=.163.com;";
ExpandedSubBlockStart.gifContractedSubBlock.gif            
/**//*            
InBlock.gif                在创建时指定了domain 属性,www.163.com及其所有下级域名都可访问
ExpandedSubBlockEnd.gif            
*/

ExpandedBlockEnd.gif        }

上面介绍了COOKIE的创建读取及不同作用域内读取的方法!
还有就是如何删除COOKIE
在ASP.net中
None.gif        private void DeleteCOOKIE(string COOKIEName)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{
InBlock.gif            
if( Request.COOKIEs[COOKIEName] != null || Request.COOKIEs[COOKIEName].Value.ToString().Trim()!="")
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                HttpCOOKIE COOKIE 
= Request.COOKIEs[COOKIEName];
InBlock.gif                COOKIE.Expires 
= DateTime.Now.AddHours(-1);//过期时间设置为一小时前
InBlock.gif
                Response.COOKIEs.Add(COOKIE);
ExpandedSubBlockEnd.gif            }

ExpandedBlockEnd.gif        }
在Javascript中
None.gif        function deleted(COOKIEName)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{
InBlock.gif            
var dat=new Date();
InBlock.gif            dat.setTime(dat.getTime()
-10000);//十秒前
InBlock.gif
            window.document.COOKIE    = COOKIEName + "=" + escape('COOKIEValue')+"; expires="+ dat.toGMTString() +";";            
InBlock.gif        
ExpandedBlockEnd.gif        }

以上就是COOKIE的一些应用,COOKIE的应用还是比较广的,有时能在解决很多问题上很方便!但COOKIE也有一性需要我们知道的知识:
COOKIE可能被禁用。当用户非常注重个人隐私保护时,他很可能禁用浏览器的COOKIE功能;
COOKIE是与浏览器相关的。这意味着即使访问的是同一个页面,不同浏览器之间所保存的COOKIE也是不能互相访问的;
COOKIE可能被删除。因为每个COOKIE都是硬盘上的一个文件,因此很有可能被用户删除;
COOKIE安全性不够高。所有的COOKIE都是以纯文本的形式记录于文件中,因此如果要保存用户名密码等信息时,最好事先经过加密处理。不过对于安全要求比较高的最好不要用COOKIE


推荐阅读
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • 本文介绍了django中视图函数的使用方法,包括如何接收Web请求并返回Web响应,以及如何处理GET请求和POST请求。同时还介绍了urls.py和views.py文件的配置方式。 ... [详细]
  • SpringMVC接收请求参数的方式总结
    本文总结了在SpringMVC开发中处理控制器参数的各种方式,包括处理使用@RequestParam注解的参数、MultipartFile类型参数和Simple类型参数的RequestParamMethodArgumentResolver,处理@RequestBody注解的参数的RequestResponseBodyMethodProcessor,以及PathVariableMapMethodArgumentResol等子类。 ... [详细]
  • 单页面应用 VS 多页面应用的区别和适用场景
    本文主要介绍了单页面应用(SPA)和多页面应用(MPA)的区别和适用场景。单页面应用只有一个主页面,所有内容都包含在主页面中,页面切换快但需要做相关的调优;多页面应用有多个独立的页面,每个页面都要加载相关资源,页面切换慢但适用于对SEO要求较高的应用。文章还提到了两者在资源加载、过渡动画、路由模式和数据传递方面的差异。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 本文介绍了使用postman进行接口测试的方法,以测试用户管理模块为例。首先需要下载并安装postman,然后创建基本的请求并填写用户名密码进行登录测试。接下来可以进行用户查询和新增的测试。在新增时,可以进行异常测试,包括用户名超长和输入特殊字符的情况。通过测试发现后台没有对参数长度和特殊字符进行检查和过滤。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • 在编写业务代码时,常常会遇到复杂的业务逻辑导致代码冗长混乱的情况。为了解决这个问题,可以利用中间件模式来简化代码逻辑。中间件模式可以帮助我们更好地设计架构和代码,提高代码质量。本文介绍了中间件模式的基本概念和用法。 ... [详细]
  • 解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法
    本文介绍了解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法,包括检查location配置是否正确、pass_proxy是否需要加“/”等。同时,还介绍了修改nginx的error.log日志级别为debug,以便查看详细日志信息。 ... [详细]
  • 本文讨论了如何在codeigniter中识别来自angularjs的请求,并提供了两种方法的代码示例。作者尝试了$this->input->is_ajax_request()和自定义函数is_ajax(),但都没有成功。最后,作者展示了一个ajax请求的示例代码。 ... [详细]
  • Servlet多用户登录时HttpSession会话信息覆盖问题的解决方案
    本文讨论了在Servlet多用户登录时可能出现的HttpSession会话信息覆盖问题,并提供了解决方案。通过分析JSESSIONID的作用机制和编码方式,我们可以得出每个HttpSession对象都是通过客户端发送的唯一JSESSIONID来识别的,因此无需担心会话信息被覆盖的问题。需要注意的是,本文讨论的是多个客户端级别上的多用户登录,而非同一个浏览器级别上的多用户登录。 ... [详细]
author-avatar
NE丰胸茶urghx
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有