php用户登录验证cookie与session区别

 更新时间:2016年11月25日 17:26  点击:1928
本文章来给各位同学介绍一下关于php用户登录验证cookie与session性能比较吧,有需要了解的同学可参考参考。


查看了不少资料。也想了很多,总结一下!

 


php高性能高流量用户登录验证机制用cookie 还是 session?

一、cookie 区别session?

cookie客户端;

session存在服务器端;

session安全。

 


二、session在分布式上存在难点。

这一点memcache可能会解决一些。但如果不用memcache,解决起来问题大.

 


三、session在生存周期上不如cookie方便。

 


四、用cookie的最大问题是服务器需要二次验证。如果用session验证,不如用session,查表也是一样。

      这里如果cookie不需要服务器端二次验证,则效率会大幅提高。 估计discuz就是这种思路。

 


五 session和cookie结合使用问题。这又分成上述各点。

最近要开发一个权限功能,我希望用户在后台选择设置好的权限会生成一个与用户对应的php文件,这样只要用户登录我就加载相对应的配置文件了,这里我们需要把用户设置的权限php数组保存到php文件中,下面我们来看实现函数
 代码如下 复制代码

<?php
function CreatePropertyArray(){
    global $IP;
 
    $content       = '';
    $industris     = array();
    $industry_tree = array();
 
    $content .= "<?phpn";
 
    //Industry
    $industries = getMasterPropertyValues('Industry');
    foreach($industries as $v){
        $industry_tree["$v"]= getSlavePropertyValues("Industry","Product Category", $v);
    }
 
    $content .= '$Industries = '. var_export($industries,true) . ";n";
 
    file_put_contents($IP . '/termwiki_array.php',$content,LOCK_EX);
 
}
 
?>
本文章来给大家介绍一个paginator的php分页程序代码,有需要的朋友可进入参考。
 代码如下 复制代码
<?php
 
class paginator {
 
    function __construct () {
 
    }
 
    static function render($page_type, array $args = array()) {
        $html = '';
        switch ($page_type)
        {
            case '1':
                $html =  page_1($channel_code, $page_num, $cur_page, $per_group, $base_url, $n, $v);
                break;
            case '2':
                $html =  fpage($row_num, $pagesize, $page, $url);
                break;
            case '3':
                break;
 
            default:
                $html = page($num, $perpage, $curpage, $mpurl, $hiddenFrom='');
        }
 
        return $html;
    }
 
 
 
    //函数1:根据总页数,当前页,和页分组及url产生分页导航
    function page_1($channel_code, $page_num, $cur_page, $per_group, $base_url, $n, $v) {
        // 分页函数参数列表(有多少页,当前页,每页多少个 ,链接地址)
        $base_url .= strpos($base_url, '?') ? '&' : '?';    //如果有?,则添加&,否则加?
 
        $page_val = "";
 
        if ($page_num < 1) {
            return $page_val; //如果小于1,返回空
        } elseif ($page_num == 1) {
            return $page_val = 1;   //如果等于1,返回1
        }
 
        //分组
 
        $group_ok = !(($page_num-1) % ($per_group-1));  //没有余数
        // 计算一共有多少组
        if($group_ok) {
            $group_num = ($page_num-1)/($per_group-1);
        }else {
            $group_num = ceil(($page_num-1) / ($per_group-1));
        } //判断当前页是否为一组的最后一个
 
 
        //组数
        $is_last_page = !(($cur_page-1) % ($per_group-1)); //计算当前在的组数
        if ($is_last_page) {
            $cur_group = ($cur_page-1) / ($per_group-1) + 1;
        } else {
            $cur_group = ceil(($cur_page-1) / ($per_group-1));
        }
 
        // 计算显示的起始页 ,这个关键
        $from = ($cur_group - 1) * ($per_group-1) + 1;
        $from = $cur_group <= 1 ? 1 :$from;
 
        $to = $from + $per_group;
        $to = $to > $page_num ? $page_num + 1 : $to;
 
        for($a = $from; $a < $to; $a++) {
            if ($a != $cur_page) {
 
                //不是当前页
                $page_val .= '<li><a href ="' . $base_url . 'channel='.$channel_code.'&n='.$n.'&v='.$v.'&page=' . $a . '">' . $a . '</a></li>';
            } else {
                //当前页
                $page_val .='<li class="current">'. $a .'</li>';
            }
        }
 
        //上一页下一页首页尾页
        $next = $cur_page + 1;    //当前页+1
        $prev = $cur_page-1;   //当前页-1
 
        if ($cur_page != $page_num) {
            //当前页不是最后一页
            $page_val .= '<span><a href ="' . $base_url . 'channel='.$channel_code.'&n='.$n.'&v='.$v.'&page=' . $next . '">' . '下一页' . '</a></span>';
            $page_val .= '<span><a href ="' . $base_url . 'channel='.$channel_code.'&n='.$n.'&v='.$v.'&page=' . $page_num . '">' . '>>' . '</a></span>'; //尾页
 
        }
        if ($cur_page != 1){
 
            //不是第一页,加上前面的内容
            $page_val = '<span><a href ="' . $base_url . 'channel='.$channel_code.'&n='.$n.'&v='.$v.'&page=' . $prev . '">' . '上一页' . '</a></span>' . $page_val;
            $page_val = '<span><a href ="' . $base_url . 'channel='.$channel_code.'&n='.$n.'&v='.$v.'&page=1">' . '<<' . '</a></span>' . $page_val; //首页
 
        }
        $page_val = '<ul class="page_nav">'.$page_val.'</ul>';
 
 
        return $page_val;
    }
 
 
 
 
    // 函数2:根据记录数,页列清数,当前页,url年成分页
    function fpage($row_num, $pagesize, $page, $url) {
        //$page,当前页;$row_num记录总数;$pagesize:每页记录数;$url记录页;
        //如果,如果有作数,则取加1
        $page_count = $row_num % $pagesize?intval($row_num / $pagesize) + 1:intval($row_num / $pagesize);
 
        if ($page_count == 1) {
            $page_string = "第一页|上一页|下一页|尾页";
        } else {
            //如果不止一页
            if ($page == 1) {
                //第一页显示
                $page_string = " <a href=" . $url . "?page=1>第一页 </a>|上一页| <a href=" . $url . "?page=" . ($page + 1) . ">下一页 </a>| <a href=" . $url . "?page=" . $page_count . ">尾页 </a>";
            }
            if (($page > 1) and ($page < $page_count)) {
                $page_string = " <a href=" . $url . "?page=1>第一页 </a>| <a href=" . $url . "?page=" . ($page-1) . ">上一页 </a>| <a href=" . $url . "?page=" .
                ($page + 1) . ">下一页 </a>| <a href=" . $url . "?page=" . $page_count . ">尾页 </a>";
            }
            if ($page == $page_count) {
                $page_string = " <a href=" . $url . "?page=1>第一页 </a>| <a href=" . $url . "?page=" . ($page-1) . ">上一页 </a>|下一页| <a href=" . $url . "?page=" . $page_count . ">尾页 </a>";
            }
        }
        $page_str = $page_string . ("," . $page . "/" . $page_count . "页");
        echo " <br> <p align=center>" . $page_str . " </p>";
    }
 
 
    /**
 * 分页函数
 *
 * @param int $num:记录总数
 * @param int $perpage:每页记录
 * @param int $curpage:当前页
 * @param string $mpurl:路径url
 * @param unknown_type $hiddenFrom
 * @return string
 */
    function page($num, $perpage, $curpage, $mpurl,$hiddenFrom='') {
        $multipage = '';
        //恢复
        $mpurl .= strpos($mpurl, '?') ? '&' : '?';
 
        if($num > $perpage) {
            $page = 10;
            $offset = 2;
 
            $pages = @ceil($num / $perpage);  //总页数
 
            if($page > $pages) {
                $from = 1;
                $to = $pages;
            } else {
                //如果总页数>10
                $from = $curpage - $offset;   //当前页-2
                $to = $from + $page - 1;    //当前页+10-3
 
                if($from < 1) {
 
                    $to = $curpage + 1 - $from;
                    $from = 1;
                    if($to - $from < $page) {
                        $to = $page;
                    }
                } elseif($to > $pages) {
                    $from = $pages - $page + 1;
                    $to = $pages;
                }
            }
 
            if ($hiddenFrom) {
                $multipage = ($curpage - $offset > 1 && $pages > $page ? '<a href="#" '.js_page($hiddenFrom,1).'>首页</a> ' : '').
                ($curpage > 1 ? ' <a href="#" '.js_page($hiddenFrom,$curpage - 1).'>‹‹上一页</a> ' : '');
                for($i = $from; $i <= $to; $i++) {
                    $multipage .= $i == $curpage ? '<span>'.$i.'</span> ' :
                    '<a href="#" '.js_page($hiddenFrom,$i).'>'.$i.'</a> ';
                }
 
                $multipage .= ($curpage < $pages ? '<a href="#" '.js_page($hiddenFrom,$curpage + 1).'>下一页››</a>' : '').
                ($to < $pages ? '<a href="#" '.js_page($hiddenFrom,$pages).'> 末页</a>' : '');
                $multipage = $multipage ? '<div class="list-page">'.$multipage.'</div>' : '';
            } else {
 
                $multipage = ($curpage - $offset > 1 && $pages > $page ? '<a href="'.$mpurl.'page=1">首页</a> ' : '').
                ($curpage > 1 ? ' <a href="'.$mpurl.'page='.($curpage - 1).'">‹‹上一页</a> ' : '');
 
                for($i = $from; $i <= $to; $i++) {
                    $multipage .= $i == $curpage ? '<span>'.$i.'</span> ' :
                    '<a href="'.$mpurl.'page='.$i.'">'.$i.'</a> ';
                }
 
                $multipage .= ($curpage < $pages ? '<a href="'.$mpurl.'page='.($curpage + 1).'">下一页››</a>' : '').
                ($to < $pages ? '<a href="'.$mpurl.'page='.$pages.'"> 末页</a>' : '');
                $multipage = $multipage ? '<div class="list-page">'.$multipage.'</div>' : '';
            }
        }
        return $multipage;
    }
    //暂不用
    function page_get_start($page, $ppp, $totalnum) {
        $totalpage = ceil($totalnum / $ppp);
        $page =  max(1, min($totalpage, intval($page)));
        return ($page - 1) * $ppp;
    }
    //暂不用
    function js_page($hiddenFrom,$page)
    {
        if ($hiddenFrom) {
            return ' onclick=javascript:$("#page").val("'.$page.'");$("#'.$hiddenFrom.'").submit(); ';
        }
    }
}
 
 
 
?>
SESSION是php中一个比较常用的东西了,我们经常把它用作记录全局页面信息,如果用户登录,后台管理,还有一个常用的就中购物车类了,下面我来给大家介绍一下。

关于 SESSION 在 php 中的应用是必不要少的,最重要的功能之一,SESSION 在网络应用中,称为“会话”,我们通常理解为存储特定用户会话所需的信息,这样,当用户在网站页面之间跳转时,存储的 SESSION 值不会丢失,而是在整个用户会话中一直存活下去。通俗一点讲,就是当用户A上网时,会创建一个ID(a)值进行保存下来,如果你的ID(A)值没有进行注销,下次上网时,这个网站还会记得你的ID(A)值,这个时候就可以在网上进行调用你的ID(A)值了,比如欢迎您ID(A)值再一次访问。

关于在 PHP 中应用 SESSION 值是很简单的,只要在顶端提前输入 session_start() 开始会话即可,下面就可以进行使用 SESSION 了,这只是小网站的应用方法,实际上,SESSION 自身还有许多属性,比如 SESSION周期,调用SESSION,SESSION数据有效期,SESSION保存,SESSION注销等等,如果有了这些属性,看起来才算是一个比较规范的SESSION应用会话。

下面是一个完整的 Session 类,整合了 Session 最基本的属性值,其中,打开,关闭与清理是符合php编程规范的,这也是一个很好的习惯。小小的说明一下,如果网站不是大量使用 Session 类,基本上就没必要使用 SESSION 类了。

 代码如下 复制代码


 <?php
/**
* 文件描述 Session类
* =================================================================
* 文件名称 session.class.php
* -----------------------------------------------------------------
* 适用环境: PHP5.2.x / mysql 5.0.x
* -----------------------------------------------------------------
* 作 者 04ie。com
* -----------------------------------------------------------------
* 创建时间 2010-2-1
* =================================================================
*/
class Session
{
/**
* session默认有效时间
* @access public
* @var ineger $_expiry
*/
public $_expiry = 3600;
/**
* 有效域名
* @access public
* @var string $_domain
*/
public $_domain = '.phpfamily.cn';
//初始化
public function __construct()
{
ini_set('session.use_trans_id', 0);
ini_set('session.gc_maxlifetime', $this->_expiry);
ini_set('session.use_cookie', 1);
ini_set('session.cookie_path', '/');
ini_set('session.cookie_domain', $this->_domain);
session_module_name('user');
session_set_save_handler(
array(&$this, 'open'),
array(&$this, 'close'),
array(&$this, 'read'),
array(&$this, 'write'),
array(&$this, 'destroy'),
array(&$this, 'gc')
);
session_start();
}
/**
* 打开session
* @access public
* @param string $savePath
* @param string $sName
* @return true
*/
public function open($savePath, $sName)
{
$this->_conn = mysql_connect('localhost', 'root', '');
mysql_select_db('databases');
mysql_query('SET NAMES "utf8"');
return true;
}
/**
* 关闭session
* @access public
* @return bool
*/
public function close()
{
return mysql_close($this->_conn);
}
/**
* 读取session
* @access public
* @param string $sid sessionID
* @return mixed
*/
public function read($sid)
{
$sql = "SELECT data FROM sessions WHERE sessionid='%s'";
$sql = sprintf($sql, $sid);
$res = mysql_query($sql, $this->_conn);
$row = mysql_fetch_assoc($res);
return !$row ? null : $row['data'];
}
/**
* 写入session
* @access public
* @param string $sid sessionID
* @param string $data serialize序列化后的session内容
* @return
*/
public function write($sid, $data)
{
$expiry = time() + $this->_expiry;
$sql = "REPLACE INTO sessions (sessionid,expiratio
n,data) VALUES ('%s', '%d', '%s')";
$sql = sprintf($sql, $sid, $expiry, $data);
mysql_query($sql, $this->_conn);
return true;
}
/**
* 销毁session
* @access public
* @param string $sid sessionID
* @return
*/
public function destroy($sid)
{
$sql = "DELETE FROM sessions WHERE sessionid='%s'";
$sql = sprintf($sql, $sid);
mysql_query($sql, $this->_conn);
return true;
}
/**
* 清理过期session
* @access public
* @param integer $time
* @return
*/
public function gc($time = 0)
{
$sql = "DELETE FROM sessions WHERE expiration < '%d'";
$sql = sprintf($sql, time());
mysql_query($sql, $this->_conn);
mysql_query('OPTIMIZE TABLE sessions');
return true;
}
 

下面我们再看一个php session购物车类

 代码如下 复制代码

<?php
class Cart{
 public function Cart() {
  if(!isset($_SESSION['cart'])){
   $_SESSION['cart'] = array();
  }
 }

 /*
 添加商品
 param int $id 商品主键
    string $name 商品名称
    float $price 商品价格
    int $num 购物数量
 */
 public  function addItem($id,$name,$price,$num,$img) {
  //如果该商品已存在则直接加其数量
  if (isset($_SESSION['cart'][$id])) {
   $this->incNum($id,$num);
   return;
  }
  $item = array();
  $item['id'] = $id;
  $item['name'] = $name;
  $item['price'] = $price;
  $item['num'] = $num;
  $item['img'] = $img;
  $_SESSION['cart'][$id] = $item;
 }

 /*
 修改购物车中的商品数量
 int $id 商品主键
 int $num 某商品修改后的数量,即直接把某商品
 的数量改为$num
 */
 public function modNum($id,$num=1) {
  if (!isset($_SESSION['cart'][$id])) {
   return false;
  }
  $_SESSION['cart'][$id]['num'] = $num;
 }

 /*
 商品数量+1
 */
 public function incNum($id,$num=1) {
  if (isset($_SESSION['cart'][$id])) {
   $_SESSION['cart'][$id]['num'] += $num;
  }
 }

 /*
 商品数量-1
 */
 public function decNum($id,$num=1) {
  if (isset($_SESSION['cart'][$id])) {
   $_SESSION['cart'][$id]['num'] -= $num;
  }

  //如果减少后,数量为0,则把这个商品删掉
  if ($_SESSION['cart'][$id]['num'] <1) {
   $this->delItem($id);
  }
 }

 /*
 删除商品
 */
 public function delItem($id) {
  unset($_SESSION['cart'][$id]);
 }
 
 /*
 获取单个商品
 */
 public function getItem($id) {
  return $_SESSION['cart'][$id];
 }

 /*
 查询购物车中商品的种类
 */
 public function getCnt() {
  return count($_SESSION['cart']);
 }
 
 /*
 查询购物车中商品的个数
 */
 public function getNum(){
  if ($this->getCnt() == 0) {
   //种数为0,个数也为0
   return 0;
  }

  $sum = 0;
  $data = $_SESSION['cart'];
  foreach ($data as $item) {
   $sum += $item['num'];
  }
  return $sum;
 }

 /*
 购物车中商品的总金额
 */
 public function getPrice() {
  //数量为0,价钱为0
  if ($this->getCnt() == 0) {
   return 0;
  }
  $price = 0.00;
  foreach ($this->items as $item) {
   $price += $item['num'] * $item['price'];
  }
  return sprintf("%01.2f", $price);
 }

 /*
 清空购物车
 */
 public function clear() {
  $_SESSION['cart'] = array();
 }
}

本文章来给大家介绍php 文件中随机取出一条数据实例,希望此教程对各位同学会有所帮助哦。
 代码如下 复制代码
<?php
//第一种方法:
$line = getrandline1('test.txt');
function getrandline1($filename)
{
 $linenum = 0;
 $fh = fopen($filename, 'r');
 while(!feof($fh))
 {
  if($rowcontents = fgets($fh))
  {
   $linenum++;
   $contens[] = $rowcontents;
  }
 }
 $randline = mt_rand(0, $linenum - 1);
 $line = $contens[$randline];
 fclose($fh);
 return $line;
}
 
//第二种方法:
$line = getrandline2('test.txt');
function getrandline2($filename)
{
 $contents = file('test.txt');
 $linenum = count($contents);
 $randline = mt_rand(0, $linenum - 1);
 $line = $contents[$randline];
 return $line;
}
 
//第三种方法:
$line = getrandline3('test.txt');
function getrandline3($filename)
{
 $contents = file('test.txt');
 shuffle($contents);
 return $contents[0];
}
 
//第四种方法:
$line = getrandline4('test.txt');
function getrandline4($filename)
{
 $linenum = 0;
 $fh = fopen($filename, 'r');
 while(!feof($fh))
 {
  if($linecontents = fgets($fh))
  {
   $linenum++;
                        $randint = (mt_rand(1, 1000000 * $linenum) - 1)/1000000);
   if($randint < 1)
   {
    $line = $linecontents;
   }
  }
 }
 fclose($fh);
 return $line;
}
?>
[!--infotagslink--]

相关文章

  • PHP session_start()很慢问题分析与解决办法

    本文章来给各位同学介绍一下关于PHP session_start()很慢问题分析与解决办法,希望碰到此问题的同学可进入参考。 最近在做东西的时候发现一个问题 有一个接口挂...2016-11-25
  • php 获取用户IP与IE信息程序

    php 获取用户IP与IE信息程序 function onlineip() { global $_SERVER; if(getenv('HTTP_CLIENT_IP')) { $onlineip = getenv('HTTP_CLIENT_IP');...2016-11-25
  • php简单用户登陆程序代码

    php简单用户登陆程序代码 这些教程很对初学者来讲是很有用的哦,这款就下面这一点点代码了哦。 <center> <p>&nbsp;</p> <p>&nbsp;</p> <form name="form1...2016-11-25
  • php根据用户语言跳转相应网页

    当来访者浏览器语言是中文就进入中文版面,国外的用户默认浏览器不是中文的就跳转英文页面。 <&#63;php $lan = substr(&#8194;$HTTP_ACCEPT_LANGUAGE,0,5); if ($lan == "zh-cn") print("<meta http-equiv='refresh' c...2015-11-08
  • PHP分布式框架如何使用Memcache同步SESSION教程

    本教程主要讲解PHP项目如何用实现memcache分布式,配置使用memcache存储session数据,以及memcache的SESSION数据如何同步。 至于Memcache的安装配置,我们就不讲了,以前...2016-11-25
  • php有效防止同一用户多次登录

    【问题描述】:同一用户在同一时间多次登录如果不能检测出来,是危险的。因为,你无法知道是否有其他用户在登录你的账户。如何禁止同一用户多次登录呢? 【解决方案】 (1) 每次登录,身份认证成功后,重新产生一个session_id。 s...2015-11-24
  • js检测用户输入密码强度

    一个用Javascript检测用户输入密码强度的效果代码,以下代码主要是从以下四个方面检测用户输入的密码的强度的,有兴趣的朋友可以自己添加或修改成自己想要的形式! 1. 如果输入的密码位数少于5位,那么就判定为弱。 2. 如果...2015-10-23
  • vue实现用户登录切换

    这篇文章主要为大家详细介绍了vue实现用户登录切换,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-04-22
  • 详解C#中的session用法

    这篇文章主要介绍了C#中的session用法 ,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下...2020-06-25
  • Python3使用Selenium获取session和token方法详解

    这篇文章主要介绍了Python3使用Selenium获取session和token方法详解,需要的朋友可以参考下...2021-02-17
  • php ajax注册验证用户名是否存在代码

    这是注册程序是一款当用户输入完用户名是,就会自动去数据库中查询用户要注册的用户名是否己经被注册了,如果是返回提示否则提示可以注册。 conn.php文件 代...2016-11-25
  • 编程新手必须掌握的:session与cookie的区别

    session和cookie是网站浏览中较为常见的两个概念,也是比较难以辨析的两个概念,但它们在点击流及基于用户浏览行为的网站分析中却相当关键。基于网上一些文章和资料的参阅,及作者个人的应用体会,对这两个概念做一个简单的阐述...2013-09-11
  • 微信小程序用户授权最佳实践指南

    这篇文章主要给大家介绍了关于微信小程序用户授权最佳实践的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-05-08
  • PHP中如何使用session实现保存用户登录信息

    session在php中是一个非常重要的东西,像我们用户登录一般都使用到session这个东西,相对于cookie来说session 要安全很多,同时我们购物车经常使用session来做临时的记录保存哦。使用session保存页面登录信息1、数据库连接...2015-10-21
  • 简单php cookie用户登录实例

    cookie 的用途之一是存储用户在特定网站上的密码和 id。另外,也用于存储起始页的首选项。在提供个人化查看的网站上,将要求阁下的网络浏览器利用阁下计算机硬驱上的少量...2016-11-25
  • Vue使用axios引起的后台session不同操作

    这篇文章主要介绍了Vue使用axios引起的后台session不同操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-08-14
  • MySQL验证用户权限的方法

    知识归纳因为MySQL是使用User和Host两个字段来确定用户身份的,这样就带来一个问题,就是一个客户端到底属于哪个host。 如果一个客户端同时匹配几个Host,对用户的确定将按照下面的优先级来排 基本观点越精确的匹配越优先...2015-11-08
  • php中session常见问题分析

    PHP的session功能,一直为许多的初学者为难。就连有些老手,有时都被搞得莫名其妙。本文,将这些问题,做一个简单的汇总,以便大家查阅。 1. 错误提示 引用 代...2016-11-25
  • sqlserver添加sa用户和密码的实现

    这篇文章主要介绍了sqlserver添加sa用户和密码的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-05-07
  • php设置session生存时间详解

    要设置php生存有效时间我们可以利用session_set_cookie_params函数或修改php.ini文件哦,下面小编来介绍一下。 第一种方法:session_set_cookie_params 函数原型 voi...2016-11-25