`

使用Cookie和用户会话

阅读更多

 

 使用Cookie和用户会话

Cookie

Cookie,存储一些关于用户的较小的信息。它和一个来自服务器或脚本的请求相一致。通过一个用户的浏览器,一个主机可以请求保存20个cookie.每个coopkie包含一个名字,值和过期日期,以及主机和路径信息。一个单个的cookie的大小限制是4kb。在设置了cookie之后,只有发出请求的主机能够读取数据,这就保证了用户隐私得到尊重。另外,用户可以配置自己的浏览器通知他接受或是拒绝所有的cookie的请求。

 

设置了一个cookie的PHP脚本发送的标头的Set-Cookie项可能如下:

Set-Cookie:vegetable=artichoke;path=/;domain=yourdomain.com

Set-Cookie标头包含:

一个名/值对(vegetable=artichoke),

一个路径(path=/)和一个域(domain=yourdomain.com)。

如果设置了expiration字段,它会提供浏览器在哪个日期“忘记”cookie的值。如果没有设置过期日期,当用户会话过期的时候,也就是当用户关掉浏览器的时候,cookie就过期了。

path字段和domain字段协同工作,因为path是找到domain的一个目录,cookie应该送回给服务器的这个目录下面。如果路径是“/”,这是很常见的值,意味着cookie可以由文档根目录下的任何文件读取。

如果路径是“/products”,这个cookie只能够被web站点的/products目录下的文件读取。

 

随后,一个PHP脚本将能够访问cookie,cookie在环境变量HTTP_COOKIE中或者作为$_COOKIE超全局变量的一部分,可以用三种方式访问它们:

echo $_SERVER["HTTP_COOKIE"];
echo getenv("HTTP_COOKIE");
echo $_COOKIE["vegetable"];

 

设置Cookie

<?php
/**
 *setcookie()函数输出一个Set-Cookie标头。它应该在任何其他内容发送给浏览器之前调用。
 *参数:cookie名字、cookie值、过期日期、路径、域、一个整数
 *如果cookie仅通过一个安全的连接发送的话,这个整数的值设为1。0表示在一个非安全的环境中发送。
 */
setcookie("vegetable","artichoke",time()+3600,"/","localhost",0);

if (isset($_COOKIE["vegetable"])){
	echo "<p>Hello again,you hava chosen:".$_COOKIE["vegetable"].".</p>";
	
}else {
	echo "<p>Hello you.This may be your first visit.</p>";
}
?> 

 

安全删除cookie的方法同样调用setcookie()函数,只需使用一个确定已经过期的时间,如:time()-60。

 

用户会话

会话函数为用户提供了一个唯一的标识符,随后可以用来存储和获取连接到该标识符的信息。当一个访客访问一个支持会话的页面,要么分配一个新的标识符,要么这个用户和之前的访问已经建立的一个标识符重新关联。任何已经和会话相关联的变量,都通过$_SESSION超全局变量变得可供你的代码使用。会话状态通常存储在一个临时文件中,尽管你可以使用一个名为session_set_save_handler()的函数实现数据库存储。

 

开始一个会话,返回ID,并存储变量,保存为session1.php。

<?php
session_start();
echo "<p>Your session ID is ".session_id().".</p>";
$_SESSION["product1"] = "Sonic Screwdriver";
$_SESSION["product2"] = "HAL 2000";
echo "The products have been registered.";
?>

访问存储的会话变量,使用session_save_path()函数查看临时文件保存在系统的什么地方,保存为sesson2.php。

<?php
session_start();
echo "Your chosen products are:";
echo "<ul>";
echo "<li>".$_SESSION["product1"]."</li>";
echo "<li>".$_SESSION["product2"]."</li>";
echo "</ul>";
echo session_save_path();
?>

先访问服务器的sesson1.php,结果如下:

 

再访问服务器下的session2.php,结果如下:

 

在该路径下 找到sess_curdcq4agn11gq4fdj4bq2kj33,用记事本打开,就可以看到已注册的变量是如何保存的。

 

当一个值放置在$_SESSION超全局变量中,PHP把变量名和值写入一个文件中,这个信息可以读取并且变量可以稍后恢复。当我们把这个变量添加到超全局变量$_SESSION后,你仍然可以在脚本执行过程中的任何时刻修改其值,但是,这个修改后的值不会反映到全局设置中,直到把这个变量重新分配给超全局变量$_SESSION。 

 

 

  • 大小: 130.8 KB
  • 大小: 129.8 KB
  • 大小: 22.1 KB
分享到:
评论

相关推荐

    练习2:使用Cookie简化用户登录.zip

    在Web开发中,用户登录是常见的功能之一,而使用Cookie技术可以有效地简化这一过程,提供更流畅的用户体验。本练习将探讨如何利用Cookie来管理用户的登录状态,从而避免频繁地发送登录请求。以下是对这个主题的详细...

    使用Cookie进行会话管理.docx

    在IT行业中,特别是JavaWeb开发领域,会话管理是一个至关重要的环节,因为它涉及到用户与服务器交互过程中的数据持久化和用户身份验证。...合理使用Cookie和Session,可以有效地提高网站的用户体验和安全性。

    PHP 会话控制 cookie 基础教程

    然而,鉴于 Cookie 的使用涉及到用户隐私和安全问题,开发者在使用 Cookie 时需要格外谨慎。正确的使用 Cookie 能够增强网站的功能性和安全性,而错误的使用则可能导致数据泄露和其他安全风险。因此,在开发过程中...

    分布式架构下的会话追踪实践【基于Cookie和Redis实现】

    本实践将探讨如何在分布式环境中实现会话追踪,主要采用Cookie和Redis这两种技术手段。 首先,我们要理解会话(Session)的概念。在Web开发中,会话是一种在用户浏览器与服务器之间维持状态的技术,允许跨多个HTTP...

    cookie 会话的操作

    在IT领域,尤其是在Web开发中,Cookie和会话管理是至关重要的概念,它们涉及到用户身份验证、状态跟踪以及用户体验优化等多个方面。以下是对"Cookie会话的操作"这一主题的详细阐述。 Cookie是一种在客户端(用户的...

    用户登录功能(cookie实现)

    10. **会话管理**:除了Cookie,ASP.NET还提供了Session状态管理,可以在服务器端存储用户会话信息。然而,Cookie在跨域共享和客户端控制方面更灵活。开发者通常结合Cookie和Session来提供更完善的用户管理。 以上...

    用户登录,会话跟踪

    1. **Cookie**:Cookie是服务器发送到用户浏览器并存储在本地的一小块数据,它包含了与用户会话相关的信息。当用户再次向服务器发送请求时,浏览器会自动将该Cookie一起发送,服务器通过解析Cookie来识别用户。...

    使用Cookie记录用户名和密码

    标题“使用Cookie记录用户名和密码”涉及到的是Web开发中的用户会话管理技术,特别是关于Cookie的应用。Cookie是一种在客户端和服务器之间传递信息的小型文本文件,常用于保持用户登录状态、存储用户偏好设置等。在...

    cookie和会话状态的工作原理 .docx

    Cookie和会话状态是Web开发中的重要概念,用于在客户端和服务器之间保持状态。本文将深入探讨这两种技术的工作原理。...正确使用Cookie和Session可以帮助开发者提供个性化的用户体验,同时确保数据的安全。

    Python-pycookiecheat从浏览器的已验证会话中获取Cookie以便在Python脚本中使用

    `pycookiecheat`是一个方便的Python库,它允许我们从已经验证的浏览器会话中提取Cookie,然后在Python脚本中使用这些Cookie来模拟登录状态。 首先,让我们深入了解一下什么是Cookie。Cookie是服务器发送到用户...

    Cookie和Session会话技术笔记

    会话技术简单介绍,会话可以简单的理解为:用户开一个浏览器,点击多个超链接,访问服务器多个web资源,然后关闭浏览器,整个过程称之为一个会话。会话过程中要解决的一些问题?每个用户与服务器进行交互的过程中,...

    cookie-session, 基于简单cookie的会话中间件.zip

    cookie-session, 基于简单cookie的会话中间件 cookie会话 基于简单...用户会话可以通过 Cookies 以两种主要方式存储: 在服务器上或者在客户端上。 这个模块在cookie中存储会话数据,而像 express会话的模块在cook

    用户会话完整性的保持

    【用户会话完整性的保持】 在信息技术领域,用户会话完整性是确保用户在...F5 Networks的多种会话保持机制体现了其对用户会话管理的深入理解和专业解决方案,旨在优化网络性能,提升用户体验,并保障数据的安全传输。

    php使用Cookie实现和用户会话的方法

    在详细介绍PHP如何使用Cookie实现和用户会话的方法之前,需要先对Cookie的概念和原理有所了解。Cookie的基本原理是,当用户第一次访问网站时,网站服务器会向用户的浏览器发送一个或多个Cookie,浏览器会将这些...

    Cookie与Session机制

    虽然Cookie和Session都可以用来跟踪用户会话,但它们各有优势和局限性。 - **使用Cookie**: - 适用于存储少量、不敏感的信息,比如用户偏好设置。 - 可以被浏览器禁用或删除。 - 存储在客户端,安全性相对较低...

    会话技术 之 cookie , session.pdf

    为了使服务器能够跟踪用户的访问状态,引入了会话跟踪技术,包括Cookie和Session。 Cookie是一种客户端会话技术,它将数据保存在客户端的浏览器中。当浏览器首次访问服务器时,如果服务器需要跟踪该用户的状态,会...

    F5会话保持

    2. 基于Cookie的会话保持:这种方法是使用Cookie来保持会话,服务器在客户端的Cookie中存储一些信息,以便识别客户的身份。F5支持多种基于Cookie的会话保持方法,包括: 2.1 cookie插入模式:在这个模式下,F5会在...

    c#实现cookie和session的登陆实例

    在Web开发中,Cookie和Session是两种常见的用户身份验证机制,尤其在C#编程语言中,它们被广泛用于实现登录功能。本实例将探讨如何在C#环境下利用Cookie和Session来处理用户登录状态。 首先,我们要理解Cookie和...

    PHP会话控制SESSION与COOKIE

    在实际开发中,开发者往往结合使用SESSION和COOKIE,比如使用SESSION存储敏感信息,使用COOKIE记录用户的非敏感偏好。合理利用这两种技术,能有效提升网站的用户体验和安全性。 为了进一步学习和实践PHP的会话控制...

    使用Cookie登录每个帐户只需登录一次,然后可以自由切换登录

    Cookie是服务器发送到用户浏览器并存储在本地的一小块数据,通常用于识别用户会话、保持登录状态。这个功能使得用户在不同页面之间或再次访问网站时无需反复输入用户名和密码,提高了用户体验。 首先,我们要理解...

Global site tag (gtag.js) - Google Analytics