更多
黑客联盟 黑客软件
学生黑客联盟
您现在的位置:学生黑客联盟 > 编程频道 > WEB开发 > 浏览信息
php之将用户信息写入数据库
时间:2015-03-20 22:06 来源:www.stuhack.com 作者:学盟网
session高级应用将用户信息写入到数据库中 首先建立数据库表 在实验数据库sqldb中建立session表,用于存储数据 在根目录下建立需要用到的文件(重点是session,class.php这个类文件,包含列一些方法) 在session.class.php中主要用到的是session_set_save_han

session高级应用将用户信息写入到数据库中

首先建立数据库表 内容来自学生黑客联盟

在实验数据库sqldb中建立session表,用于存储数据

copyright www.stuhack.com

\

学盟网

 

内容来自学生黑客联盟

在根目录下建立需要用到的文件(重点是session,class.php这个类文件,包含列一些方法) www.stuhack.com

\ copyright www.stuhack.com

在session.class.php中主要用到的是session_set_save_handler()这个方法,借助PDO进行数据操作,用类编写写入数据库表中,

copyright www.stuhack.com

类中定义了一些静态方法,其属性也要为静态的,这样session的数据就直接写入数据库中,而不是保存在本地文件夹中 内容来自学生黑客联盟

首先建立一个Session类,类中首先定义一些私有静态的属性,定义了ip,生存时间和时间 学生黑客联盟 www.stuhack.com

  本文来自学盟网(www.stuhack.com)



 
copyright www.stuhack.com
private static function init($handler){ self::$handler=$handler; //代表PDO的链接 //ip先判断不为空 self::$ip=!empty($_SERVER["REMOTE_ADDR"])? $_SERVER["REMOTE_ADDR"] : 'unkown'; //从配置文件取出生存时间 self::$lifetime=ini_get('session.gc_maxlifetime'); self::$time=time(); } 

www.stuhack.com


接下来就是定义开启session的方法

 

学盟网

  学生黑客联盟 www.stuhack.com

//定义开启session的方法
static function start(PDO $pdo){
    	self::init($pdo);  //初始化私有方法
    	session_set_save_handler(
    		array(__CLASS__,"open"),
    		array(__CLASS__,"close"),
    		array(__CLASS__,"read"),
    		array(__CLASS__,"write"),
    		array(__CLASS__,"destroy"),
    		array(__CLASS__,"gc")
    		);
    	session_start();
} www.stuhack.com 

 

www.stuhack.com

  www.stuhack.com

在开启session中有open, close, read, write, destory, gc 的方法,下面主要是定义出这些方法

open() 和 close() 方法

学盟网

 

www.stuhack.com

public static function open($path, $name){
    return true;
}
public static function close(){
    return true;
} copyright www.stuhack.com 

在定义这些方法时,最重要的是write() 和 read() 方法,因为这是直接从数据库读出或写入,采用PDO数据库预处理方式

 

www.stuhack.com

read():先进行PDO预处理,然后在获取的一条记录中,要判断ip是否为数据库中的ip,取出的数据是否已经过期,都不是就成功读出 www.stuhack.com

  本文来自学盟网(www.stuhack.com)

    public static function read($PHPSESSID){
    	$sql="select PHPSESSID,update_time,client_ip,data from session where PHPSESSID= ?"; //用?参数
    	//PDO预处理
    	$stmt=self::$handler->prepare($sql);
    	$stmt->execute(array($PHPSESSID));
    	//获取一条记录
    	if(!$result=$stmt->fetch(PDO::FETCH_ASSOC)){
    		return '';
    	}
    	//判断当前访问ip是否为数据库存在的ip
    	if(self::$ip != $result["client_ip"]){
    		self::destroy($PHPSESSID);  //销毁用户
    		return '';
    	}
    	//判断是不是过期的
    	if(($result["update_time"] + self::$lifetime) < self::$time){
    		self::destroy($PHPSESSID);
    		return '';
    	}
    	return $result['data'];  //成功读出
    } 
copyright www.stuhack.com


write():同样写入的方法也比较重要,需要判断传进来的数据是否为空,如果为空就不进行插入

 

内容来自学生黑客联盟

 

www.stuhack.com

    public static function write($PHPSESSID, $data){
    	$sql="select PHPSESSID,update_time,client_ip,data from session where PHPSESSID= ?";
    	$stmt=self::$handler->prepare($sql);
    	$stmt->execute(array($PHPSESSID));

    	if($result=$stmt->fetch(PDO::FETCH_ASSOC)){
    		//延迟30更新
    		if($result['data'] != $data || self::$time > ($result['update_time']+30)){
    			//更新数据语句
    			$sql="uptate session set update_time=?, data=? where PHPSESSID=?";
    			$stm=self::$handler->prepare($sql);
    			$stm->execute(array(self::$time, $data, $PHPSESSID));
    		}
    	}else{
    		//判断传进来的数据是否为空,空时不插入
    		if(!empty($data)){
    			$sql="insert into session(PHPSESSID,update_time,client_ip,data) values(?,?,?,?)";  //插入值用?参数
    			$sth=self::$handler->prepare($sql);
    			$sth->execute(array($PHPSESSID,self::$time,self::$ip,$data)); //必须用数组
    		}
    	}
    	return true;
    } www.stuhack.com 

接下来就是数据的销毁

  copyright www.stuhack.com

同样 destory() 和 gc() 内容来自学生黑客联盟

destory():数据删除

学生黑客联盟 www.stuhack.com

gc():垃圾回收 内容来自学生黑客联盟

  学生黑客联盟 www.stuhack.com

    public static function destroy($PHPSESSID){
    	$sql="delete from session where PHPSESSID=?";

    	$stmt=self::$handler->prepare($sql);
    	$stmt->execute(array($PHPSESSID));
    	return true;
    }
    private static function gc($lifetime){
    	$sql="delete from session where update_time < ?";
    	$stmt=self::$handler->prepare($sql);
    	$stmt->execute(array(self::$time-$lifetime));
    	return true;
    }

    } 学盟网 

最后就抛出一个异常并调用session类

  学生黑客联盟 www.stuhack.com

  本文来自学盟网(www.stuhack.com)

    try{
    	$pdo=new PDO("mysql:host=localhost;dbname=sqldb","root","heyifeng19930924");
    }catch(PDOException $e){
    	echo $e->getMessage();
    }

    //调用session类
    Session::start($pdo); 内容来自学生黑客联盟 


 

www.stuhack.com

在测试文件中,写法和session高级用法(即上一篇博客的测试文件)一样 学生黑客联盟 www.stuhack.com

只是在包含文件中包含这个类文件

学生黑客联盟 www.stuhack.com

即:include"session.class.php"; 内容来自学生黑客联盟

  学生黑客联盟 www.stuhack.com

 

copyright www.stuhack.com

测试结果,如果插入数据成功,查询表格信息,在数据库中显示:

本文来自学盟网(www.stuhack.com)

\ copyright www.stuhack.com

即传递列PHPSESSID的值 学盟网

 

学生黑客联盟 www.stuhack.com

删除撤销后,查询表格显示

学盟网

\ copyright www.stuhack.com

即撤销了PHPSESSID的值

学生黑客联盟 www.stuhack.com

 

www.stuhack.com

 

学生黑客联盟 www.stuhack.com

  copyright www.stuhack.com

 

本文来自学盟网(www.stuhack.com)

 

内容来自学生黑客联盟

  本文来自学盟网(www.stuhack.com)

 

本文来自学盟网(www.stuhack.com)

 

学盟网

  本文来自学盟网(www.stuhack.com)

 

本文来自学盟网(www.stuhack.com)

 

学盟网

 

www.stuhack.com




本文标题:php之将用户信息写入数据库

本文地址:http://www.stuhack.com/bc/web/032014270.html

免责声明:本文仅代表作者个人观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。




百度钱包“落子

一个商户通过审核入驻百度钱包,将获得百度[查看详细]

移动搜索&发

移动搜索在移动端的创新和颠覆也为百度探索[查看详细]

张向宁:移动互联

张向宁回顾了他2002年提出的“互联网十大预[查看详细]

淘宝开卖二维码门

截至4月20日,淘宝已经售出车展的实体门票[查看详细]

百度钱包杀入移动

“百度钱包”将完成的 “搜索用户”与“消[查看详细]