php SESSION入库的实现
session入库,就是重写session制机,在session的周期内,获得到session的数据并记录到数据库
Session默认是存放到服务器上的文件中,不方便管理,如果能把session存放到数据库中就可以方便的对数据库进行管理了
比如:
session入库可以解决哪些问题?
1. 可以解决跨域操作
2. 可以实现单点登陆
3. 可以统计在线人数
4. 可以实现同一时只允许一个用户在线
session_set_save_handler的回掉函数描述
实现session入库
第一步:在php.ini配置文件中设置session.save_headler=user(默认是file)
或者使用ini_set设置ini_set(‘session.save_handler’,’user’);
第二步:创建一个存放session的数据表
session_id用于存放session_id的,字段类型为字符型,长度为32
session_value用于存放session的内容,字段类型为text
session_life 用于存放session的生存期
第三步:session_set_save_handler ( callback $open , callback $close ,callback $read , callback $write , callback $destroy , callback $gc )
第四步:代码实现
<?php
header('content-type:text/html;charset=utf-8'); //将session存储方式设置为存入数据库的方式
//session.save_handler = files
ini_set("session.save_handler", "user"); session_set_save_handler("open", "close", "read", "write", "destroy", "gc"); //打开并连接数据库
function open()
{
//使用pdo
$pdo = new PDO('mysql:host=127.0.0.1;dbname=yii','root','root');
$pdo->exec('set names utf8');
} //关闭连接
function close()
{
//使用pdo
$pdo = new PDO('mysql:host=127.0.0.1;dbname=yii','root','root');
$pdo->exec('set names utf8');
$pdo = null;
} //从表中中读信息
function read($session_id)
{
//使用pdo
$pdo = new PDO('mysql:host=127.0.0.1;dbname=yii','root','root');
$pdo->exec('set names utf8');
$read = $pdo->query("select * from session where session_id='$session_id'")->fetch(PDO::FETCH_ASSOC);
return $read["session_info"];
} //将session存入数据库
function write ($session_id,$session_info)
{
// echo $session_id. " " . $session_info;
//使用pdo
$pdo = new PDO('mysql:host=127.0.0.1;dbname=yii','root','root');
$pdo->exec('set names utf8');
$read = $pdo->query("select * from session where session_id='$session_id'")->fetch(PDO::FETCH_ASSOC); if(empty($read))
{
$time = time();
$pdo->exec("insert into session (session_id, session_info, session_life) values ('$session_id', '$session_info', '$time')");
}
else
{
$sql = "update session set session_info='$session_info' where session_id='$session_id'";
$pdo->exec($sql);
}
} //销毁指定session
function destroy($session_id)
{
//使用pdo
$pdo = new PDO('mysql:host=127.0.0.1;dbname=yii','root','root');
$pdo->exec('set names utf8');
$pdo->exec("delete from session where session_id='$session_id'");
} //删除所有过期的session
function gc()
{ } session_start();
//判断是否有session
if(isset($_SESSION['name']))
{ $status = 1;
}
else
{
$status = 0; } //获取需要接收的值
$user_name = isset($_POST['user_name'])?$_POST['user_name']:null;
$user_pwd = isset($_POST['user_pwd'])?$_POST['user_pwd']:null;
//使用pdo
$pdo = new PDO('mysql:host=127.0.0.1;dbname=yii','root','root');
$pdo->exec('set names utf8');
$sql = "select * from user where username = '$user_name' and password = '$user_pwd' ";
$re = $pdo->query($sql)->fetch(PDO::FETCH_ASSOC);
if($re)
{
$status = 1;
$_SESSION['name'] = $user_name;
} ?>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<body>
<?php if($status == 0){?>
<h3>服务器3</h3>
<form action="a.php" method="post">
<table>
<tr>
<td>姓名:</td>
<td><input type="text" name="user_name"></td>
</tr>
<tr>
<td>密码:</td>
<td><input type="password" name="user_pwd"></td>
</tr>
<tr>
<td></td>
<td><input type="submit" value="登录"></td>
</tr>
</table>
</form>
<?php } else{?>
<h2>欢迎<?=$_SESSION['name']?>登录</h2>
<h3>服务器3</h3>
<?php }
?>
</body>
</html>
php SESSION入库的实现的更多相关文章
- Session 入库
session入库 session机制中的数据分部分存储,1部分在客户端的cookie中,2部分在服务器端的session文件中. 务器端的session文件中存储的是$_SESSION变量中的数据. ...
- session高级(session入库)
我们知道,session是一种会话技术,用来实现跨脚本共享数据. 在之前的php会话技术中我们介绍过,session是存放在服务器端的文件里的,因此session有可能因为文件数量过多,会在查询ses ...
- php实现session入库
为什么要把session存入数据库?有什么用? 可以:统计在线人数,现实多站点session共享(通行证),控制同个账号登入人数等. 要实现session的入库,有关键的几个基本知识: session ...
- php中session 入库的实现
ini_set("session.save_handler","user");//session.gc_probability = 1 分子ini_set(&q ...
- PHP 实现Session入库/存入redis
对于大访问量的站点使用默认的Session 并不合适,我们可以将其存入数据库.或者使用Redis KEY-VALUE数据存储方案 首先新建一个session表 CREATE TABLE `sessio ...
- session入库
#存储session的数据表示列结构,可作为参考#创建数据库(可选)CREATE DATABASE session;#使用创建的数据库(可选)USE session;#创建存储session的数据表( ...
- Session自定义存储及分布式存储
默认情况下,PHP 使用内置的文件会话保存管理器(files)来完成会话的保存.我们无需设置,PHP默认将session以文件的形式保存到服务器. 通过调用函数 session_start() 即可手 ...
- PHP的学习--cookie和session
最近读了一点<PHP核心技术与最佳实践>,看了cookie和session,有所收获,结合之前的认识参考了几篇博客,总结一下-- 1. PHP的COOKIE cookie 是一种在远程浏览 ...
- Cookie与Session详解
来源:<PHP核心技术与最佳实践> 列旭松 陈文 著 Cookie与Session详解读书笔记,从概念.操作.应用.注意事项以及区别等几方面详细阐述两者的基础知识,它们都是针对HTTP协议 ...
随机推荐
- 食物链-HZUN寒假集训
食物链 总时间限制: 1000ms 内存限制: 65536kB 描述 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃C,C吃A. 现有N个动物,以1-N编号.每个动 ...
- 判断某个方法是否存在,解析php函数function_exists (),method_exists()与is_callable()的区别
php函数function_exists (),method_exists() 与is_callable()的区别在哪? 先来讲下后两个:method_exists() 与is_callable(): ...
- jdk和tomcat环境配置
一.安装JDK和Tomcat 1,安装JDK:直接运行jdk-7-windows-i586.exe可执行程序,默认安装即可. 备注:路径可以其他盘符,不建议路径包含中文名及特殊符号. 2.安装Tomc ...
- lintcode 链表求和
题目要求 你有两个用链表代表的整数,其中每个节点包含一个数字.数字存储按照在原来整数中相反的顺序,使得第一个数字位于链表的开头.写出一个函数将两个整数相加,用链表形式返回和. 样例 给出两个链表 3- ...
- Hype-v 共享文件办法
Hype-v在Windows下跑Windows系统,其效率要远好于VMWare,唯一蛋疼的就是剪贴板不能复制文件.共享文件的方案就剩下以下几种: 远程访问 虚拟磁盘 挂载镜像 挂载镜像把每个文件都制作 ...
- cocos2dx中的坐标系统
一. (1)OpenGL坐标系 Cocos2D-x以OpenGL和OpenGL ES为基础,所以自然支持OpenGL坐标系.该坐标系原点在屏幕左下角,x轴向右,y轴向上. (2)屏幕坐标系 屏幕坐标系 ...
- C/C++静态代码安全检查工具
静态代码安全检查工具是一种能够帮助程序员自动检测出源程序中是否存在安全缺陷的软件.它通过逐行分析程序的源代码,发现软件中潜在的安全漏洞.本文针对 C/C++语言程序设计中容易存在的多种安全问题,分别分 ...
- Python_生成大量随机信息
#coding=utf-8 import random import string import codecs ''' 演示如何使用Python标准库random来生成随机数据,这在需要 ''' #常 ...
- 第七章之S5PV210移植到Nandflash
1,之前的操作都是基于SD卡进行运行的,如今在Nandfalsh中运行u-boot.因为s5p_goni.h配置文件没有配置Nand相关文件,所以先配置Nand文件. 在include/configs ...
- vue国际化高逼格多语言
## 1.NPM 项目安装 ``` cnpm i vue-i18n ``` ## 2.使用方法 ``` /* 国际化使用规则 */ import Vue from 'vue' import VueI1 ...