• JavaScript之读取和写入cookie


      首先先让我们简单地了解一下cookie.
      在我们制作网页的过程中,经常需要把信息从一个页面传递给另一个页面,这时候就需要用到JavaScript中的cookie机制了。简单说来,cookie提供了一种便捷的方式,能够在用户的计算机上保存少量数据并且远程获得它们,从而让网站可以保存一些细节信息,比如用户的习惯设置或是上一次访问网站的时间。cookie本身是一些短小的信息,能够由页面保存在用户的计算机上,然后被其他页面读取。cookie一般都设置为在一定时间后失效。
      当然,cookie也有局限之处:浏览器对于能够保存的cookie数量有所限制,通常是几百个或者多一点。一般情况下,每个域名20个cookies是允许的,而每个域最多能保存4KB的cookie.除了大小限制可能导致的问题,也有很多原因会引起硬盘上的cookie消失,比如达到有效期限了,或是用户清理了cookie信息,或是换用了其他浏览器。因此,cookie不适合用来保存重要数据,在编写代码时也要考虑到cookie获取异常的处理方法。
      在JavaScript中,使用document对象的cookie属性来储存和获取cookie.通常,document.cookie里的信息是由成对的名称和值组成的字符串,每一对数据的形式是:

    name=value;

      下面我们将通过一个简单的例子来展示在JavaScript中如何读取和写入cookie.
      首先是createCookie.html,在该页面中会创建一个cookie,完整的代码如下:

    <html>
    <head>
    	<title>createCookie</title>
    	<script>
    		function createCookie(){
    		    //get name and password
    			var name = document.getElementById("name").value;
    			var pwd = document.getElementById("pwd").value;
    			//create cookie
    			document.cookie = name+'|'+pwd;
    			//go to showCookie.html page
    			window.location.href = "showCookie.html";
    		}
    	</script>
    </head>
    <body>
    	Userame:&nbsp;&nbsp;<input id="name" type="text" /><br><br>
    	Password:&nbsp;&nbsp;<input id="pwd" type="password" /><br><br>
    	<button onclick="createCookie()">Submit</submit>
    </body>
    </html>
    

    该页面的截图如下:

    ![createCookie.html](http://img.blog.csdn.net/20180127133018029?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvamNsaWFuOTE=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
    点击submit按钮,就会创建一个cookie,在该cookie中保存了Username和Password信息,并且会跳转到showCookie.html页面。其中,showCookie.html页面的完整代码如下: ```html showCookie

    ``` 页面截图如下:
    ![showCookie.html](http://img.blog.csdn.net/20180127133838458?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvamNsaWFuOTE=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
    点击show Cookie按钮就会显示cookie里面的信息了。   下面,我们将会在本地和服务器上分别跑这个程序,分别在IE浏览器和Chrome浏览器上运行这个程序,看看cookie的运行情况。   首先我们在本地运行这个程序,我们将上述两个文件都放在E盘中。先在IE浏览器上运行,在createCookie.html页面上输入信息,并点击submit按钮,截图如下:
    ![IE浏览器createCookie.html](http://img.blog.csdn.net/20180127134413411?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvamNsaWFuOTE=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
    跳转到showCookie.html页面后,点击show Cookie按钮,页面截图如下:
    ![本地 IE浏览器showCookie.html](http://img.blog.csdn.net/20180127134637934?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvamNsaWFuOTE=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
    cookie在本地环境中的IE浏览器中运行正常。   接下来,我们看看在Chrome浏览器中运行情况,首先在Chrome浏览器中打开createCookie.html页面,输入信息,并点击submit按钮,截图如下:
    ![本地 Chrome浏览器createCookie.html](http://img.blog.csdn.net/20180127134944502?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvamNsaWFuOTE=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
    跳转到showCookie.html页面后,点击show Cookie按钮,页面截图如下:
    ![Chrome浏览器showCookie.html](http://img.blog.csdn.net/20180127135052062?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvamNsaWFuOTE=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
    同样的程序,这次cookie在Chrome浏览器中却运行失败了。   接着让我们在服务器中运行这个程序,需要用到xampp,并打开Apache服务器,将上述两个html文件放在xampp安装文件夹下的htdocs文件夹下(具体的操作方法可以参考这篇博客:[JavaScript之使用AJAX(适合初学者)](http://blog.csdn.net/jclian91/article/details/79087152))。我们现在IE浏览器中运行该程序,在IE浏览器中输入网址:http://localhost/createCookie.html,截图如下:
    ![服务器 IE浏览器 createCookie.html](http://img.blog.csdn.net/20180127135747284?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvamNsaWFuOTE=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
    点击Submit按钮,跳转到showCookie.html页面,并点击show Cookie按钮,截图如下:
    ![服务器 IE浏览器 showCookie.html](http://img.blog.csdn.net/20180127140020039?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvamNsaWFuOTE=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
      然后我们在Chrome浏览器中输入网址:http://localhost/createCookie.html,截图如下:
    ![服务器 Chrome浏览器 createCookie.html](http://img.blog.csdn.net/20180127140259654?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvamNsaWFuOTE=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
    点击Submit按钮,跳转到showCookie.html页面,并点击show Cookie按钮,截图如下:
    ![服务器 Chrome浏览器 showCookie.html](http://img.blog.csdn.net/20180127140340416?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvamNsaWFuOTE=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
    这次在服务器环境下,IE浏览器和Chrome浏览器的cookie都运行正常!   本次分享到此结束,欢迎大家交流~~
  • 相关阅读:
    逆向分析实战
    打印工程内所有方法的调用
    JAVA B/S系统实现客户端屏幕截图,Java版的QQ截图
    让input支持 ctrl v上传粘贴图片? 让input支持QQ截图或剪切板中的图像数据(Java实现保存)
    spring4 security 4 +websocket 实现单点登录
    Spring quartz 单机、集群+websocket集群实现文本、图片、声音、文件下载及推送、接收及显示
    spring 4.2.0后jdbcTemplate中不用queryForLong了(之系统升级发现)
    友好解决POI导入Excel文件行是不是为空
    解决POI读取Excel如何判断行是不是为空
    集群: 如何在spring 任务中 获得集群中的一个web 容器的端口号?
  • 原文地址:https://www.cnblogs.com/jclian91/p/8365936.html
Copyright © 2020-2023  润新知