第113+114+115+116讲 cookie①-cookie原理介绍 创建cookie获取cookie

image
image
image
image
image

cookies win7路径

C:\Users\Administrator\AppData\Roaming\Microsoft\Windows\Cookies

cookie

Cookie,有时也用其复数形式 Cookies,指某些网站为了辨别用户身份、进行 session 跟踪而储存在用户本地终端上的数据(通常经过加密)。定义于 RFC2109 和 2965 中的都已废弃,最新取代的规范是 RFC6265[1] 。(可以叫做浏览器缓存)

简介:

  • Cookie 是在 HTTP 协议下,服务器或脚本可以维护客户工作站上信息的一种方式。Cookie 是由 Web 服务器保存在用户浏览器(客户端)上的小文本文件,它可以包含有关用户的信息。无论何时用户链接到服务器,Web 站点都可以访问 Cookie 信息[2] 。

  • 目前有些 Cookie 是临时的,有些则是持续的。临时的 Cookie 只在浏览器上保存一段规定的时间,一旦超过规定的时间,该 Cookie 就会被系统清除[2] 。

  • 持续的 Cookie 则保存在用户的 Cookie 文件中,下一次用户返回时,仍然可以对它进行调用。在 Cookie 文件中保存 Cookie,有些用户担心 Cookie 中的用户信息被一些别有用心的人窃取,而造成一定的损害。其实,网站以外的用户无法跨过网站来获得 Cookie 信息。如果因为这种担心而屏蔽 Cookie,肯定会因此拒绝访问许多站点页面。因为,当今有许多 Web 站点开发人员使用 Cookie 技术,例如 Session 对象的使用就离不开 Cookie 的支持[2] 。

功能:

  • 在同一个页面中设置 Cookie,实际上是按从后往前的顺序进行的。如果要先删除一个 Cookie,再写入一个 Cookie,则必须先写写入语句,再写删除语句,否则会出现错误[2] 。

  • Cookie是面向路径的。缺省路径 (path) 属性时,Web 服务器页会自动传递当前路径给浏览器,指定路径强制服务器使用设置的路径。在一个目录页面里设置的 Cookie 在另一个目录的页面里是看不到的 [2] 。

  • Cookie 必须在 HTML 文件的内容输出之前设置;不同的浏览器 (Netscape Navigator、Internet Explorer) 对 Cookie 的处理不一致,使用时一定要考虑;客户端用户如果设置禁止 Cookie,则 Cookie 不能建立。 并且在客户端,一个浏览器能创建的 Cookie 数量最多为 300 个,并且每个不能超过 4KB,每个 Web 站点能设置的 Cookie 总数不能超过 20 个[2] 。

image

image

cookie代码示范

<?php
//创建cookie信息
//将用户名和密码保存到客户端的cookie
//第一个参数表示cookie的一个key,第二个参数表示value,第三个参数表示保存的时长
setcookie("name","qb",time()+3600);

echo "123";

对如上代码解释:

  • ①、当浏览器访问界面时候,服务器会以
    Set-Cookie:name=qb; expires=Thu, 15-Jun-2017 10:56:08 GMT 此种类型保存该cookie到
  • ②、如果我们没有该时间(第三个参数)cookie不会保存到本地客户端,当浏览器会话结束,cookie就失效了
  • ③、注意cookie仅仅只能保存字符串
setcookie("lastvisit",date("Y-m-d H:i:s"),time()+3600*2);

if (!empty($_COOKIE)){
	echo "您上次访问时间为".$_COOKIE['lastvisit'];
}

有可能你在使用显示上次登录的时间时候会提示一个时区错误 因为 php 默认不设置时区。。那么就只能自己设置了
1、php文件中设置 (date_default_timezone_set 用这个函数 系统提供的直接在写代码时候设置下)

date_default_timezone_set("Asia/Chongqing");

2、php.ini文件中设置
image
增加登陆setcookieNameWork1.4.rar
部分示例代码

<form method="post" action="LoginProcess.php">
<table border='1px' width='400px'>
	<tr>
		<td>用户登陆</td>
	</tr>
</table>
<br />
用户名:<input type="text" name='username' value='<?php echo getCookieVal("username")?>' /><br />
密 码:<input type="password" name='password' value='' /><br />
是否要保存cookies<input type="checkbox" name="iscookies" value="iscookies"/><br />
<input type="submit" value='提交' /></form>
if (!empty($_POST['iscookies'])){
	echo "用户需要保存账号密码";
	setcookie("username",$username,time()+3600*7);
}else {
	echo "用户不需要保存账号密码";
	if (!empty($_COOKIE['username'])){
		setcookie("username",$username,time()-100);
	}
}
function getCookieVal($key){
	if (!empty($_COOKIE[$key])){
		return $_COOKIE[$key];
	}else {
		return "";
	}

}

涉及文件
login.php;
LoginProcess.php;
Utils.php;
setcookie(“username”,$username);
这样保存不设置过期时间的话,不会保存到本地但是能访问到生命周期也就是浏览器的开关。关了就访问不到了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

有时有晌

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值