Cookie与Session
Cookie和session是目前使用的两种存储机制。
cookie是从一个WEB页到下一个WEB页面的数据传送方法,cookie存储在客户端。
Session是让数据在页面中持续有效的一个传递方法,session存储在服务器端。
掌握了cookie与session这两个技术,在WEB网站页面间信息传递的安全性是非常必要的,也是必不可少的。
一、 Cookie管理
1、 Cookie
Cookie是一种在远程浏览器端存储数据并以此跟踪和识别用户的机制。简单的说,cookie是WEB服务器暂时存储在用户硬盘上的一个文本文件,并随后被WEB浏览器读取。当用户在次访问WEB网站时,网站通过读取cookie文件记录这位访客的特定信息(如上次访问的位置、花费的时间、用户名和密码等)从而迅速做出响应,如在页面中不需要输入用户名和密码等,就可以直接登录网站等。文本文件的命令格式如下:
用户名@网站地址[数字].txt
打开”我的电脑”—C盘(系统盘)---documentsand settings—administrator—cookie
这个路径就是cookie文件存储的路径。Administrator是当前使用的用户名,也就是登录本机的用户名,administrator@sogou[1].txt是指定格式自动生成的cookie文件,index.dat是用来保储所有打开的WEB网站的信息,该文件会随着用户打开的网站随时进行更新,在cookie文件夹下的每一个cookie文件都是一个简单而又普通的文本文件,而不是程序。Cookie中的内容大多是经过了加密处理的,因此表面看起来只是一些字母和数字的组合,这些内容只有服务器才知道他们真正的含义。
Cookie常用于以下3个方面:
记录访客的某些信息。如可以利用cookie记录用户访问网页的次数,或者记录访客曾经输入过的信息,另外,某些网站可以应用cookie自动记录访客上次登录的用户名。
在页面之间传递变量。浏览器并不会保存当前页面上任何变量信息的,当页面被关闭,页面上的任何变量信息将随之消失。如果用户声明一个变量id=8,要把这个变量传递到另一个页面,可以把变量id以cookie形式保存下来,然后在下一页通过读取该cookie来获取变量的值。
将所查看的internet页礁在cookie临时文件夹中,这样可以提高以后浏览的速度。
2、 创建Cookie
在PHP中通过setcookie函数创建Cookie。在创建之前必须了解的是,cookie是HTTP头标的组成部分,而头标必须在页面其他内容之前发送,它必须最先输出,即使在setcookie()函数前输出一个HTML标记或echo语句,甚至一个空行都会导致程序出错。语法如下:
Bool setcookie(string name[,string value[,int expire [,stringpath [,string domain [,int secure]]]]])
该函数的参数说明如表:
Name cookie的变量名 可以通过$_cookie[“cookiename”]调用变量名cookiename的cookie
Value cookie的变理名 该值保存在客户端不能用来保存敏感数据。可以通过$_cookie[“value”]获取名为values的值
Expire cookie的失效时间,expire是标准的UNIX时间标记,可以用time()函数或mktime()函数获取,单位为秒。
Path cookie在服务器端的有效路径 如果该参数设置为“/”,则它就在整个domain下的/11目录及子目录内有效。默认是当前目录。
Domain cookie有效的域名 如果要使cookie在mrbccd.com域名下的所有子域都有效,应该设置为mrbccd.com
Secure 指明cookie是否通过仅通过安全的https,值为0或1,如果值为1,则cookie只能在HTTPS连接上有效,如果值为默认值0,则cookie在HTTP和HTTPS连接上均有效。
例:
setcookie("TMCcookie","www.baidu.com");
setcookie("TMCcookie","www.baidu.com",time()+60); //设置cookie有效时间为60秒
setcookie("TMCcookie",$value,time()+3600,"/cs/","baidu.com",1);
?>
3、 读取Cookie
在PHP中可以直接通过超级全局数据$_cookie[]来读取浏览器端的cookie值。
例:
if(!isset($_COOKIE["visittime"])){ //检测cookie文件是否存在,如果不存在,往下执行
setcookie("visittime",date("y-m-d H:i:s")); //设置一个cookie变量
echo "欢迎第一次访问网站。";
}else{
setcookie("visittime",date("y-m-dH:i:s"),time()+60); //如果存在,设置上带cookie失效时间的变量。
echo "您上一次访问的时间为:".$_COOKIE["visittime"];
echo " ";
}
echo "您本次访问网站的时间为:".date("y-m-dH:i:s");
?>
过60秒后我们刷新,则显示的是第一次访问的时间。
如果未设置cookie的到期时间,则在关闭浏览器时自动删除cookie数据。如果为cookie设置了到期时间,浏览器将会记住cookie数据,即使用户重新启动计算机,只要没有到期,再访问网站时也会获得数据信息。
4、 删除Cookie
当cookie被创建后,如果没有设置它的失效时间,其cookie文件会在关闭浏览器时被自动删除。如果想在关闭浏览器之前删除cookie文件,方法有两种:一种是使用setcookie()函数删除,另一种是使用浏览器手动删除cookie。
(1)、使用setcookie()函数删除cookie
删除cookie和创建cookie的方式基本类似,删除cookie也使用setcookie()函数。删除cookie只需要将setcookie()函数中第二个参数设置为空值,将第三个参数cookie的过期时间设置为小于系统的当前时间即可。
例如:将cookie的过期时间设置为当前时间减1秒,代码如下:
setcookie("name","",time()-1);
time()函数返回以秒表示的当前时间戳,把过期时间减1秒就会得到过去的时间,从而删除cookie. 注意:把过期时间设置为0,可以直接删除cookie.
(2)、使用浏览器手动删除cookie
在使用cookie时,cookie自动生成一个文本文件存储在IE浏览器的cookies临时文件夹中。使用浏览器删除cookie文件是非常便捷的方法。
打开一个页面-----工具-----internet选项,在“常规”选项卡------删除cookie按钮,弹出“删除temporaryinternet files文件夹中的所有cookies吗?”-----单击“确定”,即可成功删除全部cookie文件。
5、 Cookie的生命周期
如果cookie不设定时间,就表示它的生命周期为浏览器会话的期间,只要关闭IE浏览器,cookie就会自动消失。这种cookie被称为会话cookie,一般不保存在硬盘上,而是保存在内存中。
如果设置了过期时间,那么浏览器会把cookie保存到硬盘中,再次打开IE浏览器时会被依然有效,直到它的有效期超时。
虽然cookie可以长期保存在客户端浏览器中,但也不是一成不变的。因为浏览器允许最多存储300个cookie文件,而且每个cookie文件支持最大容量为4KB,每个域名最多支持20个cookie,如果达到限制,浏览器会自动地随机删除cookies.
6、 Cookie的综合应用
在进行网站开发时,都需要制作一个计数器来记录网站的访问量,以此来吸引更多的访客关注网站。
例:
if(!empty($_COOKIE["counter"])){
$counter=$_COOKIE["counter"]+1;
}
else{
$counter=1;
}
setcookie("counter",$counter,time()+2678400);
echo "您是第".$counter."位访客。";
?>
关闭浏览器时也不会停止记数,除非C:\Documents and Settings\Administrator\LocalSettings\Temporary Internet Files将文件进行删除才可以。
计数器的实现方法有多种。
二、 Session管理
对比cookie,会话文件中保存的数据是在PHP脚本中以变量的形式创建的,创建的会话变量在生命周期(20分钟)中可以被跨页的请求所引用。另外,session是存储在服务器端的会话,相对安全,并且不像cookie那样有存储长度的限制。
1、 了解session
Session被译成中文为“会话”,其本义是指有始有终的一系列动作/消息,如打电话。
在计算机专业术语中,session是指一个终端用户与交互系统进行通信的时间间隔,通常指从注册进入系统到注销退出系统之间所经过的时间。因此,session实现上是一个特定的时间概念。
2、 Session的功能
Session在WEB技术中占有非常重要的份量。由于网页是一种无状态的连接程序。因此无法得知用户的浏览状态。因此必须通过session记录用户的有关信息,以供用户再次以此身份对WEB服务器提供要求时作确认。例,在电子商务网站中,通过session记录用户登录的信息,以及用户所购买的商品,如果没有session,那么用户就会每进入一个页面都登录一遍用户名和密码。
另外,session会话适用于存储用户的信息量比较小的情况。如果用户需要存储的信息量相对较少,并用对存储内容不需要长期存储,那么使用session把信息存储到服务器端比较适合。
3、 创建会话
创建一个会话需要通过以下几个步骤实现:
启动会话--------注册会话-------使用会话-------删除会话
1) 启动会话
启动会话的方式有两种:一种是使用session_start()函数,另一种使用session_register()函数为会话登录一个变量来隐含地启动会话。
通常,session_start()函数在页面开始位置调用,然后会话变量被登录到数据$_session。
其语法格式为:
Bool session_start(void);
使用session_start()函数之前浏览器不能有任何输出,否则会产生类似以下的错误提示。
如果想使用session_satrt()这个全局变量来存储你的数据的话得在php.ini文件中配置你的信息:
session.save_path = "D:/program files/php/temp"
例:
echo "呵呵……";
session_start();
?>
运行结果如下:
呵呵……
Warning : session_start()[ function.session-start]:Cannot send session cache limiter - headers already sent (output started atC:\webserver\wwwroot\11.php:1) in
C:\webserver\wwwroot\11.php on line
3
session_start();
?>
注意:该代码前不要有任何的代码,如果新建的文件默认有的内容,要删除。
Session_register()函数用来为会话登录一个变量来隐含地启动会话,但要求设置php.ini文件的选项,将register_globals指令设置为ON,然后重新启动apache服务器。
使用session_register()函数时,不需要调用session_start()函数,PHP会在注册变量之后隐含地调用session_start()函数。
2) 注册会话
会话变量被启动后,全部保存在数组$_session中。通过数组$_session创建一个会话变量很容易,只要直接给该数组添加一个元素即可。
例:
session_start();
$_SESSION["admin"]=null;
?>
3) 使用会话
首先需要判断会话变量是否有一个会话ID存在,如果不存在,就创建一个,并且使用其能够通过全局数组$_SESSION进行访问。如果已经存在,则将这个已注册的会话变量载入以供用户使用。
例:
session_start();
$_SESSION["admin"]=id;
if(!empty($_SESSION["admin"])){
$myvalue=$_SESSION["admin"];
echo $myvalue;
}else{
echo "该会话不存在。";
}
?>
4) 删除会话
删除会话的方法主要有删除单个会话、删除多个会话和结束当前会话的3种。
a) 删除单个会话
删除会话变量,同数组的操作一样,直接注销$_SESSION数组的某个元素即可。
例如:注销$_SESSION[“admin”]变量,可以使用unset()函数,代码如下:
unset($_SESSION["admin"]);
b) 删除多个会话
如果想要一次注销所有的会话变量,可以将一个空的数组赋值给$_SESSION,代码如下:
$_SESSION=array();
c) 结束当前的会话
如果整个会话已经结束,首先应该注销所有的会话变量,然后使用session_destroy()函数清除结束当前的会话,并清空会话中的所有资源,彻底销毁session,代码如下:
session_destroy();
4、 Session的综合应用----通过session判断用户的操作权限
大多数网站的开发过程中,需要对管理员和普通用户对操作网站的权限进行划分。
例:13.php
用session判断用户操作权限
用户名:
密 码:
check_13.php
session_start();
$_SESSION[user]=$_POST[user];
$_SESSION[pwd]=$_POST[pwd];
?>
check_13.php
if($_SESSION[user]==""){
echo"";
}
if($_SESSION[user]=="123" &&$_SESSION[pwd]=="123"){
echo "您是管理员用户 ";
}else{
echo "您是普通用户";
}
?>
session_start();
unset($_SESSION[user]);
unset($_SESSION[pwd]);
session_destroy();
?>
三、 Cookie与Session的比较
它们最大的区别是Session是将Session的信息保存在服务器上,并通过一个Sessionid来传递客户的信息,同时服务器接收到Sessionid后,根据这个ID来提供相关的Session资源;cookie是将所有的信息以文本文件的形式保存在客户端,并由浏览器进行管理和维护。
由于session为服务器存储,所以远程用户无法修改session文件的内容。而cookie为客户端存储,所以session要比cookie安全得多。当然使用session还有很多优点,如控制容易,可以按照用户自定义存储(存储于数据库)。
你可能感兴趣的:(session_cookie)
.net session_cookie简介
诺亚蜗牛_Snail
cookiecookie是什么?存储在客户端浏览器(客户端硬盘)中的一段数据。cookie的作用?保存用户的状态信息。(会话跟踪)cookie的主要作用就是用来保存状态的。因为http协议是无状态的,所以要想保存用户的状态信息,必须自己来实现,可以通过cookie来实现。cookie的特点:1.保存的数据量大小有限制。2.cookie可以设置有效期。当把有效期设置为已经过期的日期,那么浏览器就会删
haproxy负载均衡保持客户端和服务器Session亲缘性的三种方式:
kexl
haproxy cookie balance
1用户IP识别haroxy将用户IP经过hash计算后指定到固定的真实服务器上(类似于nginx的IPhash指令)配置指令 balancesource2cookie识别 haproxy将WEB服务端发送给客户端的cookie中插入(或添加加前缀)haproxy定义的后端的服务器COOKIEID。配置指令例举 cookie SESSION_COOKIE insertindirectnocac
java杨辉三角
3213213333332132
java基础
package com.algorithm;
/**
* @Description 杨辉三角
* @author FuJianyong
* 2015-1-22上午10:10:59
*/
public class YangHui {
public static void main(String[] args) {
//初始化二维数组长度
int[][] y
《大话重构》之大布局的辛酸历史
白糖_
重构
《大话重构》中提到“大布局你伤不起”,如果企图重构一个陈旧的大型系统是有非常大的风险,重构不是想象中那么简单。我目前所在公司正好对产品做了一次“大布局重构”,下面我就分享这个“大布局”项目经验给大家。
背景
公司专注于企业级管理产品软件,企业有大中小之分,在2000年初公司用JSP/Servlet开发了一套针对中
电驴链接在线视频播放源码
dubinwei
源码 电驴 播放器 视频 ed2k
本项目是个搜索电驴(ed2k)链接的应用,借助于磁力视频播放器(官网:
http://loveandroid.duapp.com/ 开放平台),可以实现在线播放视频,也可以用迅雷或者其他下载工具下载。
项目源码:
http://git.oschina.net/svo/Emule,动态更新。也可从附件中下载。
项目源码依赖于两个库项目,库项目一链接:
http://git.oschina.
Javascript中函数的toString()方法
周凡杨
JavaScript js toString function object
简述
The toString() method returns a string representing the source code of the function.
简译之,Javascript的toString()方法返回一个代表函数源代码的字符串。
句法
function.
struts处理自定义异常
g21121
struts
很多时候我们会用到自定义异常来表示特定的错误情况,自定义异常比较简单,只要分清是运行时异常还是非运行时异常即可,运行时异常不需要捕获,继承自RuntimeException,是由容器自己抛出,例如空指针异常。
非运行时异常继承自Exception,在抛出后需要捕获,例如文件未找到异常。
此处我们用的是非运行时异常,首先定义一个异常LoginException:
/**
* 类描述:登录相
Linux中find常见用法示例
510888780
linux
Linux中find常见用法示例
·find path -option [ -print ] [ -exec -ok command ] {} \;
find命令的参数;
SpringMVC的各种参数绑定方式
Harry642
springMVC 绑定 表单
1. 基本数据类型(以int为例,其他类似):
Controller代码:
@RequestMapping("saysth.do")
public void test(int count) {
}
表单代码:
<form action="saysth.do" method="post&q
Java 获取Oracle ROWID
aijuans
java oracle
A ROWID is an identification tag unique for each row of an Oracle Database table. The ROWID can be thought of as a virtual column, containing the ID for each row.
The oracle.sql.ROWID class i
java获取方法的参数名
antlove
java jdk parameter method reflect
reflect.ClassInformationUtil.java
package reflect;
import javassist.ClassPool;
import javassist.CtClass;
import javassist.CtMethod;
import javassist.Modifier;
import javassist.bytecode.CodeAtt
JAVA正则表达式匹配 查找 替换 提取操作
百合不是茶
java 正则表达式 替换 提取 查找
正则表达式的查找;主要是用到String类中的split();
String str;
str.split();方法中传入按照什么规则截取,返回一个String数组
常见的截取规则:
str.split("\\.")按照.来截取
str.
Java中equals()与hashCode()方法详解
bijian1013
java set equals() hashCode()
一.equals()方法详解
equals()方法在object类中定义如下:
public boolean equals(Object obj) {
return (this == obj);
}
很明显是对两个对象的地址值进行的比较(即比较引用是否相同)。但是我们知道,String 、Math、I
精通Oracle10编程SQL(4)使用SQL语句
bijian1013
oracle 数据库 plsql
--工资级别表
create table SALGRADE
(
GRADE NUMBER(10),
LOSAL NUMBER(10,2),
HISAL NUMBER(10,2)
)
insert into SALGRADE values(1,0,100);
insert into SALGRADE values(2,100,200);
inser
【Nginx二】Nginx作为静态文件HTTP服务器
bit1129
HTTP服务器
Nginx作为静态文件HTTP服务器
在本地系统中创建/data/www目录,存放html文件(包括index.html)
创建/data/images目录,存放imags图片
在主配置文件中添加http指令
http {
server {
listen 80;
server_name
kafka获得最新partition offset
blackproof
kafka partition offset 最新
kafka获得partition下标,需要用到kafka的simpleconsumer
import java.util.ArrayList;
import java.util.Collections;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.
centos 7安装docker两种方式
ronin47
第一种是采用yum 方式
yum install -y docker
 
java-60-在O(1)时间删除链表结点
bylijinnan
java
public class DeleteNode_O1_Time {
/**
* Q 60 在O(1)时间删除链表结点
* 给定链表的头指针和一个结点指针(!!),在O(1)时间删除该结点
*
* Assume the list is:
* head->...->nodeToDelete->mNode->nNode->..
nginx利用proxy_cache来缓存文件
cfyme
cache
user zhangy users;
worker_processes 10;
error_log /var/vlogs/nginx_error.log crit;
pid /var/vlogs/nginx.pid;
#Specifies the value for ma
[JWFD开源工作流]JWFD嵌入式语法分析器负号的使用问题
comsci
嵌入式
假如我们需要用JWFD的语法分析模块定义一个带负号的方程式,直接在方程式之前添加负号是不正确的,而必须这样做:
string str01 = "a=3.14;b=2.71;c=0;c-((a*a)+(b*b))"
定义一个0整数c,然后用这个整数c去
如何集成支付宝官方文档
dai_lm
android
官方文档下载地址
https://b.alipay.com/order/productDetail.htm?productId=2012120700377310&tabId=4#ps-tabinfo-hash
集成的必要条件
1. 需要有自己的Server接收支付宝的消息
2. 需要先制作app,然后提交支付宝审核,通过后才能集成
调试的时候估计会真的扣款,请注意
应该在什么时候使用Hadoop
datamachine
hadoop
原帖地址:http://blog.chinaunix.net/uid-301743-id-3925358.html
存档,某些观点与我不谋而合,过度技术化不可取,且hadoop并非万能。
--------------------------------------------万能的分割线--------------------------------
有人问我,“你在大数据和Hado
在GridView中对于有外键的字段使用关联模型进行搜索和排序
dcj3sjt126com
yii
在GridView中使用关联模型进行搜索和排序
首先我们有两个模型它们直接有关联:
class Author extends CActiveRecord {
...
}
class Post extends CActiveRecord {
...
function relations() {
return array(
'
使用NSString 的格式化大全
dcj3sjt126com
Objective-C
格式定义The format specifiers supported by the NSString formatting methods and CFString formatting functions follow the IEEE printf specification; the specifiers are summarized in Table 1. Note that you c
使用activeX插件对象object滚动有重影
蕃薯耀
activeX插件 滚动有重影
使用activeX插件对象object滚动有重影 <object style="width:0;" id="abc" classid="CLSID:D3E3970F-2927-9680-BBB4-5D0889909DF6" codebase="activex/OAX339.CAB#
SpringMVC4零配置
hanqunfeng
springmvc4
基于Servlet3.0规范和SpringMVC4注解式配置方式,实现零xml配置,弄了个小demo,供交流讨论。
项目说明如下:
1.db.sql是项目中用到的表,数据库使用的是oracle11g
2.该项目使用mvn进行管理,私服为自搭建nexus,项目只用到一个第三方 jar,就是oracle的驱动;
3.默认项目为零配置启动,如果需要更改启动方式,请
《开源框架那点事儿16》:缓存相关代码的演变
j2eetop
开源框架
问题引入
上次我参与某个大型项目的优化工作,由于系统要求有比较高的TPS,因此就免不了要使用缓冲。
该项目中用的缓冲比较多,有MemCache,有Redis,有的还需要提供二级缓冲,也就是说应用服务器这层也可以设置一些缓冲。
当然去看相关实现代代码的时候,大致是下面的样子。
[java]
view plain
copy
print
?
public vo
AngularJS浅析
kvhur
JavaScript
概念
AngularJS is a structural framework for dynamic web apps.
了解更多详情请见原文链接:http://www.gbtags.com/gb/share/5726.htm
Directive
扩展html,给html添加声明语句,以便实现自己的需求。对于页面中html元素以ng为前缀的属性名称,ng是angular的命名空间
架构师之jdk的bug排查(一)---------------split的点号陷阱
nannan408
split
1.前言.
jdk1.6的lang包的split方法是有bug的,它不能有效识别A.b.c这种类型,导致截取长度始终是0.而对于其他字符,则无此问题.不知道官方有没有修复这个bug.
2.代码
String[] paths = "object.object2.prop11".split("'");
System.ou
如何对10亿数据量级的mongoDB作高效的全表扫描
quentinXXZ
mongodb
本文链接:
http://quentinXXZ.iteye.com/blog/2149440
一、正常情况下,不应该有这种需求
首先,大家应该有个概念,标题中的这个问题,在大多情况下是一个伪命题,不应该被提出来。要知道,对于一般较大数据量的数据库,全表查询,这种操作一般情况下是不应该出现的,在做正常查询的时候,如果是范围查询,你至少应该要加上limit。
说一下,
C语言算法之水仙花数
qiufeihu
c 算法
/**
* 水仙花数
*/
#include <stdio.h>
#define N 10
int main()
{
int x,y,z;
for(x=1;x<=N;x++)
for(y=0;y<=N;y++)
for(z=0;z<=N;z++)
if(x*100+y*10+z == x*x*x
JSP指令
wyzuomumu
jsp
jsp指令的一般语法格式: <%@ 指令名 属性 =”值 ” %>
常用的三种指令: page,include,taglib
page指令语法形式: <%@ page 属性 1=”值 1” 属性 2=”值 2”%>
include指令语法形式: <%@include file=”relative url”%> (jsp可以通过 include