php怎么把session保存到MySql数据库中
php中session默认的存储方式是硬盘,php也可以改变默认的存储方式。
主要使用到session_set_save_handler方法,下面分享下如何将session保存到MySql数据库中的具体代码。
1.建session表
代码如下 | 复制代码 |
CREATE TABLE `session` ( `sessionid` varchar(128) NOT NULL, `uid` int(11) NOT NULL, `data` mediumblob NOT NULL, `timestamp` int(11) NOT NULL, `ip` varchar(15) NOT NULL, PRIMARY KEY (`sessionid`), KEY `time_session` (`timestamp`,`sessionid`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8; |
uid 是保留字段
2.自定义session类
代码如下 | 复制代码 |
<?php private $conn; public static function getInstance(){ return $instance; public function __construct(){ public function __destruct(){ public function open(){ public function close(){ mysql_close($this->conn); public function read($id){ public function write($id,$data){ public function destroy($id){ public function gc($lifetime){ public function query($query){ ?> |
3.测试程序
代码如下 | 复制代码 |
<?php CustomSession::getInstance(); session_start(); $_SESSION['username']='feng'; print_r($_SESSION); ?> |
运行测试程序后,查看数据库可以发现session表中已经增加了session记录
防盗链就是对一些文件资源进行包装了,这样对方是看不到我们文件源地址了,下载是也是php文件打开了,下载成功之后就成了要下载的文件了,下面我来给各位分享一站长写的类。悲剧,刚提交的既然服务器挂了没成功,又得重写....
这几天在写一个PHP防盗链外部资源下载处理函数,昨天晚上刚完成编写,中间遇到了些问题,这里就不详述了;
以下是自写的简单的PHP防盗链处理类(重新整理编写成类文件,以便后期改进);
代码如下 | 复制代码 |
<?php 002 /** 003 * 004 * 防盗链外部资源下载处理类 005 * 006 * @author 清风 <xrcc_bk@126.com> 007 * @link http://blog.emtalk.net 008 * 009 */ 010 class BurglarDow{ 011 /** 012 * 初始许可下载状态 013 * @var allow 014 * @access private 015 */ 016 private $allow = false; 017 /** 018 * 初始下载地址 019 * @var dowUrl 020 * @access private 021 */ 022 private $dowUrl = null; 023 /** 024 * 初始来路域名 025 * @var RemoteUrl 026 * @access private 027 */ 028 private $RemoteUrl = null; 029 /** 030 * 初始许可资源取用域名列表 031 * @var allowUrl 032 * @access private 033 */ 034 private $allowUrl = array(); 035 /** 036 * 初始转跳地址 037 * @var Location 038 * @access private 039 */ 040 private $Location = null; 041 042 public function __construct($dowUrl,$Location,array $allowUrl){ 043 // 初始下载地址 044 $this->dowUrl = $dowUrl; 045 // 初始许可资源取用域名列表 046 $this->allowUrl = $allowUrl; 047 // 初始转跳地址 048 $this->Location = $Location; 049 050 $this->RemoteUrl = @parse_url($_SERVER['HTTP_REFERER']); // 获取来路域名 051 if(!is_array($this->RemoteUrl)) 052 header("HTTP/1.1 301 Moved Permanently"); 053 header("Location: ".$this->Location); 054 055 if(isset($this->RemoteUrl['host'])){ 056 if(in_array($this->RemoteUrl['host'],$this->allowUrl)){ // 判断是否来至许可域名 057 $this->allow = true; // 下载许可状态为:真 058 } 059 } 060 unset($this->allowUrl,$this->RemoteUrl); // 释放内存变量 061 } 062 063 /** 064 * 防盗链资源下载 065 * @access public 066 * @return mixed 067 */ 068 public function dow(){ 069 $FileInfo = get_headers($this->dowUrl,1); // 获取远程文件头部信息 070 071 if(true === $this->allow){ // 判断是否许可下载资源 072 //判断配置文件是否存在 073 if(is_file('Config.ini')){ 074 $FileCon = parse_ini_file('Config.ini'); 075 }else{ 076 $FileName = basename($FileInfo['Content-Location']); 077 $FileConStr = "FileName = {$FileName}rnFileUrl = {$FileInfo['Content-Location']}rnFileSize = {$FileInfo['Content-Length']}"; 078 $handle = fopen ('Config.ini', "wb"); // Config.ini文件不存在则创建文件 079 if (fwrite ($handle, $FileConStr) == FALSE) { // 数据写入文件 080 echo "File creation failed ..."; 081 } 082 fclose ($handle); // 关闭一个已打开的文件指针 083 $FileCon = parse_ini_file('Config.ini'); 084 } 085 if(!empty($$this->dowUrl)){ 086 $fp = @fopen($$this->dowUrl, "rb"); // 二进制模式读取文件 087 if (!$fp) 088 exit("Download a mistake.nn"); 089 090 // 输出远程资源 091 header("Content-type:text/html;charset=utf-8"); 092 header('Content-Description: File Transfer'); 093 header('Content-Type: application/octet-stream'); 094 header('Content-Disposition: attachment; filename='.$FileCon['FileName']); 095 header("Accept-Ranges: bytes"); 096 header('Content-Transfer-Encoding: binary'); 097 header('Expires: 0'); 098 header('Cache-Control:must-revalidate,post-check=0,pre-check=0'); 099 header('Pragma: public'); 100 header('Content-Length: '.$FileCon['FileSize']); 101 while (!feof($fp)){ 102 set_time_limit(0); // 设置文件最长执行时间 103 echo fread($fp, 1024); // 输出文件 104 flush(); // 输出缓冲 105 ob_flush(); // 输出缓冲区中的内容 106 } 107 fclose($fp); 108 }else{ 109 header("HTTP/1.1 404 Not Found"); 110 } 111 }else{ 112 header("HTTP/1.1 301 Moved Permanently"); 113 header("Location: ".$this->Location); 114 } 115 } 116 } 117 // 远程资源地址 118 $dowUrl = '/qq/QQ5.1/10055/QQ5.1.exe'; 119 // 转跳地址 120 $Location = 'http://www.111cn.net'; 121 // 许可来路域名列表 122 $allowUrl = array( 123 'blog.emtalk.net', 124 ); 125 $BurglarDow = new BurglarDow($dowUrl,$Location,$allowUrl); 126 $BurglarDow -> dow(); |
有何不足之处,还望访友们多指点指点;
我这里写的是用curl的代码
本地代码如下:
代码如下 | 复制代码 |
<?php |
远程服务器接受端代码:
代码如下 | 复制代码 |
<?php |
例子,同样是利用curl不过这是利用ftp
代码如下 | 复制代码 |
<?php |
二维条码/二维码可以分为堆叠式/行排式二维条码和矩阵式二维条码。堆叠式/行排式二维条码形态上是由多行短截的一维条码堆叠而成;矩阵式二维条码以矩阵的形式组成,在矩阵相应元素位置上用“点”表示二进制“1”,用“空”表示二进制“0”,“点”和“空”的排列组成代码。
堆叠式/行排式二维条码,如,Code 16K、Code 49、PDF417等。
矩阵式二维码,最流行莫过于QR CODE。
矩阵式二维码存储的数据量更大;可以包含数字、字符,及中文文本等混合内容;有一定的容错性(在部分损坏以后可以正常读取);空间利用率高等。
代码如下 | 复制代码 |
<?php function generateQRfromGoogle($vname,$vtel,$widhtHeight ='150',$EC_level='L',$margin='0')
|
php生成网址二维码:
代码如下 | 复制代码 |
<?php function generateQRfromGoogle($chl,$widhtHeight ='150',$EC_level='L',$margin='0') |
例子
代码如下 | 复制代码 |
<?php /* * php 生成二维码名片 * api Google * google api 二维码生成【QRcode可以存储最多4296个字母数字类型的任意文本,具体可以查看二维码数据格式】 * @param string $chl 二维码包含的信息,可以是数字、字符、二进制信息、汉字。不能混合数据类型,数据必须经过UTF-8 URL-encoded.如果需要传递的信息超过2K个字节,请使用POST方式 * @param int $widhtHeight 生成二维码的尺寸设置 * @param string $EC_level 可选纠错级别,QR码支持四个等级纠错,用来恢复丢失的、读错的、模糊的、数据。 * L-默认:可以识别已损失的7%的数据 * M-可以识别已损失15%的数据 * Q-可以识别已损失25%的数据 * H-可以识别已损失30%的数据 * @param int $margin 生成的二维码离图片边框的距离 * 二维码名片的格式---vcard * 格式参考如下: BEGIN:VCARD VERSION:3.0 FN:用户名 TEL;CELL;VOICE:0571-00000000 TEL;WORK;VOICE:0571-00000000 TEL;WORK;FAX:0571-00000000 EMAIL;PREF;INTERNET:361way URL:http://www.111cn.net orG:361way运维之路 ROLE:研发部 TITLE:CTO ADR;WORK;POSTAL:杭州市西湖区XXX号;310000 REV:2014-2-26T08:30:02Z END:VCARD 如果你想更详细的定制所需要的格式,则需要详细的了解vcard的格式标准。 */ $vcard = array( 'vname' => '用户名', 'vtel' => '13800000000', 'vemail' => 'aaaaa@163.com', 'vaddress' => '杭州市西湖区', ); generateQRfromGoogle($vcard); function generateQRfromGoogle($vcard,$widhtHeight ='150',$EC_level='L',$margin='0') { if($vcard){ $chl = "BEGIN:VCARDnVERSION:3.0". //vcard头信息 "nFN:".$vcard['vname']. "nTEL:".$vcard['vtel']. "nEMAIL:".$vcard['vemail']. "nADR:".$vcard['vaddress']. "nEND:VCARD"; //vcard尾信息 echo '<img src="http://chart.apis.google.com/chart?chs='.$widhtHeight.'x'.$widhtHeight.'&cht=qr&chld='.$EC_level.'|'.$margin.'&chl='.urlencode($chl).'" alt="QR code" widhtHeight="'.$size.'" widhtHeight="'.$size.'"/>'; } } ?> |
如果想实现中间有logo的效果,需要通过另外一个logo小图进行拼接即可。这里只提供一种实现方法,也可以通过QRcode的方式进行生成。
vcode的标准信息可以参看维基百科 。
注:有些生成的图片经扫描没有的数据的原因是编码导致的,该问题在windows下较常见,由于很多编辑器默认提供的是ANSI编码,更改成utf8就OK了。
今天公司要做一个提问的功能全部使用ajax操作了,这里我只拿其它的一个分类二级下拉效果ajax例子,希望此文章对你会有帮助。html代码
代码如下 | 复制代码 |
<select id="teId" name="te_id" onchange="getArea()"> |
ajax代码
代码如下 | 复制代码 |
// 创建ajax引擎 if (window.ActiveXObject) { xmlHttpRequest = new ActiveXObject("Microsoft.XMLHTTP"); xmlHttpRequest = new XMLHttpRequest(); return xmlHttpRequest; var myXmlHttpRequest = ""; function getArea(){ myXmlHttpRequest.open("post", url, true); |
php代码
代码如下 | 复制代码 |
$str = ''; if(!$teamId) { $str .= '<select name="te_tid">'; $str .= ' <option value="1000">--请选择分类--</option>'; $str .= '</select>'; echo $str; exit; } else { $str .= '<select id="teTid" name="te_tid">'; $str .= ' <option value="1000">--请选择分类--</option>'; foreach($teamId as $v) { $str .= '<option value="'.$v['id'].'">'.$v['tname'].'</option>'; } $str .= '</select>'; echo $str; } |
本站原创教程:转载注明来源 http://www.111cn.net 否则后果自负
相关文章
PHP session_start()很慢问题分析与解决办法
本文章来给各位同学介绍一下关于PHP session_start()很慢问题分析与解决办法,希望碰到此问题的同学可进入参考。 最近在做东西的时候发现一个问题 有一个接口挂...2016-11-25- 操作类就是把一些常用的一系列的数据库或相关操作写在一个类中,这样调用时我们只要调用类文件,如果要执行相关操作就直接调用类文件中的方法函数就可以实现了,下面整理了...2016-11-25
- 本文给大家分享C#连接SQL数据库和查询数据功能的操作技巧,本文通过图文并茂的形式给大家介绍的非常详细,需要的朋友参考下吧...2021-05-17
- 这篇文章主要介绍了C#从数据库读取图片并保存的方法,帮助大家更好的理解和使用c#,感兴趣的朋友可以了解下...2021-01-16
- 这篇文章主要介绍了Intellij IDEA连接Navicat数据库的方法,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借价值,需要的朋友可以参考下...2021-03-25
- 在开发过程中,我们经常会将日期时间的毫秒数存放到数据库,但是它对应的时间看起来就十分不方便,我们可以使用一些函数将毫秒转换成date格式。 一、 在MySQL中,有内置的函数from_unixtime()来做相应的转换,使用如下: 复制...2014-05-31
- C#使用System.IO中的文件操作方法在Windows系统中处理本地文件相当顺手,这里我们还总结了在Oracle中保存文件的方法,嗯,接下来就来看看整理的C#操作本地文件及保存文件到数据库的基本方法总结...2020-06-25
- 通过内网连另外一台机器的mysql服务, 确发现速度N慢! 等了大约几十秒才等到提示输入密码。 但是ping mysql所在服务器却很快! 想到很久之前有过类似的经验, telnet等一些服务在连接请求的时候,会做一些反向域名解析(如果...2015-10-21
- 某些时候,例如为了搭建一个测试环境,或者克隆一个网站,需要复制一个已存在的mysql数据库。使用以下方法,可以非常简单地实现。假设已经存在的数据库名字叫db1,想要复制一份,命名为newdb。步骤如下:1. 首先创建新的数据库newd...2015-10-21
- mysqldump命令的用法1、导出所有库系统命令行mysqldump -uusername -ppassword --all-databases > all.sql 2、导入所有库mysql命令行mysql>source all.sql; 3、导出某些库系统命令行mysqldump -uusername -ppassword...2015-10-21
- 1005:创建表失败1006:创建数据库失败1007:数据库已存在,创建数据库失败1008:数据库不存在,删除数据库失败1009:不能删除数据库文件导致删除数据库失败1010:不能删除数据目录导致删除数据库失败1011:删除数据库...2013-09-23
- 这篇文章主要介绍了c#从数据库里取得数据并异步更新ui的方法,大家参考使用吧...2020-06-25
- yii2.0框架是PHP开发的一个比较高效率的框架,集合了作者的大量心血,下面通过用户为例给大家详解yii2使用中的一些基本的增删改查操作。 User::find()->all(); //返回所有用户数据; User::findOne($id); //返回 主键...2015-11-24
PHP分布式框架如何使用Memcache同步SESSION教程
本教程主要讲解PHP项目如何用实现memcache分布式,配置使用memcache存储session数据,以及memcache的SESSION数据如何同步。 至于Memcache的安装配置,我们就不讲了,以前...2016-11-25- 1.用phpmyadmin创建数据库和数据表 创建数据库的时候,请将“整理”设置为:“utf8_general_ci” 或执行语句: 复制代码 代码如下:CREATE DATABASE `dbname` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci; 创...2015-10-21
- 这篇文章主要介绍了springBoot 项目排除数据库启动方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-09-10
- 这篇文章主要介绍了Linux 下使用shell脚本定时维护数据库,本文通过案例分析给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-07-11
- 这篇文章主要介绍了C#中的session用法 ,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下...2020-06-25
Python3使用Selenium获取session和token方法详解
这篇文章主要介绍了Python3使用Selenium获取session和token方法详解,需要的朋友可以参考下...2021-02-17- “主机,用户名,密码”得到连接、“数据库,sql,连接”得到结果,最后是结果的处理显示。当然,数据库连接是扩展库为我们完成的,我们能做的仅仅是处理结果而已。...2013-09-29