<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 


<html xmlns="http://www.w3.org/1999/xhtml"> 


<head> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 

<title>login</title>

<script type="text/javascript">

//新建cookie。

//hours为空字符串时,cookie的生存期至浏览器会话结束。

hours为数字0时,建立的是一个失效的cookie,这个cookie会覆盖已经建立过的同名、同path的cookie(假设这个cookie存在)。

//设置cookie

function setCookie(name,value,hours,path){  

    var name = escape(name);  

    var value = escape(value);

    var expires = new Date();

    expires.setTime(expires.getTime() + hours*3600000);  

    path = path == "" ? "" : ";path=" + path;  

    _expires = (typeof hours) == "string" ?

"" : ";expires=" + expires.toUTCString();  


    document.cookie = name + "=" + value + _expires + path;  

}  

//获取cookie值  

function getCookieValue(name){  

    var name = escape(name);  

    //读cookie属性,这将返回文档的全部cookie  

    var allcookies = document.cookie;         

    //查找名为name的cookie的開始位置  

    name += "=";  

    var pos = allcookies.indexOf(name);      

    //假设找到了具有该名字的cookie,那么提取并使用它的值  

    if(pos != -1){                                      //假设pos值为-1则说明搜索"version="失败  


        var start = pos + name.length;                  //cookie值開始的位置  

        var end = allcookies.indexOf(";",start);        //从cookie值開始的位置起搜索第一个";"的位置,即cookie值结尾的位置  


        if (end == -1) end = allcookies.length;   //假设end值为-1说明cookie列表里仅仅有一个cookie  


        var value = allcookies.substring(start,end); //提取cookie的值  

        return unescape(value);                         //对它解码        

    }else

  return "";          //搜索失败。返回空字符串  

}  

//删除cookie  

function deleteCookie(name,path){  

    var name = escape(name);  

    var expires = new Date(0);  

    path = path == "" ? "" : ";path=" + path;  

    document.cookie = name + "="+ ";expires=" + expires.toUTCString() + path;  

}

function $(objStr){return document.getElementById(objStr);}  

window.onload = function(){

   //分析cookie值,显示上次的登陆信息  

    var userNameValue = getCookieValue("userName");  

    $("userName").value = userNameValue;  

   var passwordValue = getCookieValue("password");  

    $("password").value = passwordValue;      

   //写入点击事件  

    $("submit").onclick = function()  

    {  

        var userNameValue = $("userName").value;  

        var passwordValue = $("password").value;  

        //server验证(模拟)      

        var isAdmin = userNameValue == "admin" && passwordValue =="123456";  

        var isUserA = userNameValue == "userA" && passwordValue =="userA";  

        var isMatched = isAdmin || isUserA;  

        if(isMatched){

            if( $("saveCookie").checked){    

                setCookie("userName",$("userName").value,24,"/");

                setCookie("password",$("password").value,24,"/");

            }

            alert("登陆成功,欢迎你," + userNameValue + "!");  

            self.location.replace("welcome.html");  

        }  

        else alert("username或password错误。请又一次输入!");      

    }  

}

</script> 

</head> 

<body> 

<form action=""> 

<p> 

    <span>UserName:</span> 

   <input id="userName" type="text" value=""/></p> 

<p> 

    <span>Password:</span> 

    <input id="password" type="password" value=""/></p> 

<p> 

    <span style="font-size:12px; color:blue;">记住password</span> 

   <input id="saveCookie" type="checkbox" value="" /></p> 

<p> 

    <input id="submit" type="button" value="GO" /> 

</p> 

</form> 

</body> 

</html>

浏览器登录cookie的更多相关文章

  1. IE/Firefox/Chrome等浏览器保存Cookie的位置

    IE/Firefox/Chrome等浏览器保存Cookie的位置 原文  http://smilejay.com/2013/04/browser-cookie-location/   前面写了篇长文( ...

  2. 删除浏览器浏览器删除cookie方法

    上班之余抽点时光出来写写博文,希望对新接触的朋友有帮助.今天在这里和大家一起学习一下删除浏览器 文章目录导航 适用范围及演示工具 什么是cookie? cookie有什么作用? ie6/ie7/ie8 ...

  3. c#获取新浪微博登录cookie

    用新浪微博api收集数据有诸多限制,每小时只能调用官方api函数150次,认证也很麻烦.因此想通过爬网页的方式来收集数据.访问新浪微博用户网页首先需要登录,登录获取cookie后可直接获取网页数据,无 ...

  4. 浏览器存储(cookie、localStorage、sessionStorage)

    互联网早期浏览器是没有状态维护,这个就导致一个问题就是服务器不知道浏览器的状态,无法判断是否是同一个浏览器.这样用户登录.购物车功能都无法实现,Lou Montulli在1994年引入到web中最终纳 ...

  5. Python3+Selenium2完整的自动化测试实现之旅(四):Selenium-webdriver操作浏览器、Cookie、鼠标键盘、警示框、设置等待时间、多窗口切换

    本篇学习总结webdriver模块操作浏览器.Cookie.鼠标键盘.警示框.设置等待时间.多窗口切换等方法的使用 1    浏览器控制 Selenium-webdriverAPI提供了对页面元素定位 ...

  6. 关于PHP中浏览器禁止Cookie后,Session能使用吗?

    sessionid是存储在cookie中的,解决方案如下: Session URL重写,保证在客户端禁用或不支持COOKIE时,仍然可以使用Session session机制.session机制是一种 ...

  7. 第三百三十三节,web爬虫讲解2—Scrapy框架爬虫—Scrapy模拟浏览器登录—获取Scrapy框架Cookies

    第三百三十三节,web爬虫讲解2—Scrapy框架爬虫—Scrapy模拟浏览器登录 模拟浏览器登录 start_requests()方法,可以返回一个请求给爬虫的起始网站,这个返回的请求相当于star ...

  8. Postman+Postman interceptor的安装和使用-解决把chrome浏览器登录状态同步到postman进行有依赖的接口测试 Postman 使用方法详解

    Postman+Postman interceptor的安装和使用-解决把chrome浏览器登录状态同步到postman进行有依赖的接口测试   问题引入:做接口测试时,有依赖关系的接口往往不好测试( ...

  9. 十二 web爬虫讲解2—Scrapy框架爬虫—Scrapy模拟浏览器登录—获取Scrapy框架Cookies

    模拟浏览器登录 start_requests()方法,可以返回一个请求给爬虫的起始网站,这个返回的请求相当于start_urls,start_requests()返回的请求会替代start_urls里 ...

随机推荐

  1. sql server 存储过程中使用变量表,临时表的分析(续)

    最近,我有一朋友,对我说他的数据库中的很多存储过程,执行都是超时.让我替他看看是什么原因.我一看,原来他的存储过程中用了很多的临时表与变量表.于是我跟他说过犹不及. 在存储过程中使用临时表或变量表,使 ...

  2. mybatis-mysql小优化

    原文:http://blog.csdn.net/jinzhencs/article/details/51656548 1.查询某条记录是否存在 <!-- 查询s是否被创建过:Uuid,name, ...

  3. VUE -- ejs模板的书写

    1.EJS是一个简单高效的模板语言,通过数据和模板,可以生成HTML标记文本.可以说EJS是一个JavaScript库,EJS可以同时运行在客户端和服务器端,客户端安装直接引入文件即可,服务器端用np ...

  4. Cocos2dx 粒子销毁问题

    Cocos2dx    粒子销毁问题 DionysosLai(906391500@qq.com) 2014-7-3 之前在调试粒子特效时,在粒子编辑器有个选项是用来调整粒子的生命时间,当粒子存在的时间 ...

  5. util.date.js

    ylbtech-JavaScript-util: util.date.js 日期处理工具 1.A,JS-效果图返回顶部   1.B,JS-Source Code(源代码)返回顶部 1.B.1, m.y ...

  6. java执行linux shell命令,并拿到返回值

    package com.pasier.xxx.util; import java.io.IOException; import java.io.InputStream; import java.nio ...

  7. CentOS6.4 安装 codeblocks-12.11

    FROM: http://blog.csdn.net/theegao/article/details/8750239 一.下载 1.   codeblocks-12.11-1.el6.x86_64.t ...

  8. 剑指offer——链表相关问题总结

    首先统一链表的数据结构为: struct ListNode { int val; struct ListNode *next; ListNode(int x) :val(x), next(NULL) ...

  9. 设计模式之十八:桥接模式(Bridge)

    桥接模式: 将抽象部分和它的实现部分相分离开来,以使它们能够单独地变化. UML图: 主要包含: Abstraction:定义了抽象部分的接口.操作一个实现部分对象的引用. RefinedAbstra ...

  10. iOS项目开发之仿网易彩票推荐应用

    简介 效果展示 思路分析 代码实现 Git地址 一.简介 某些公司有较多的产品时,通常会在一个产品中推广另外的一些产品,我简单的封装了一个UIControllerView,由于不同公司,要求不同.所以 ...