php用户登录验证cookie与session区别
查看了不少资料。也想了很多,总结一下!
php高性能高流量用户登录验证机制用cookie 还是 session?
一、cookie 区别session?
cookie客户端;
session存在服务器端;
session安全。
二、session在分布式上存在难点。
这一点memcache可能会解决一些。但如果不用memcache,解决起来问题大.
三、session在生存周期上不如cookie方便。
四、用cookie的最大问题是服务器需要二次验证。如果用session验证,不如用session,查表也是一样。
这里如果cookie不需要服务器端二次验证,则效率会大幅提高。 估计discuz就是这种思路。
五 session和cookie结合使用问题。这又分成上述各点。
代码如下 | 复制代码 |
<?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); } ?> |
代码如下 | 复制代码 |
<?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 在网络应用中,称为“会话”,我们通常理解为存储特定用户会话所需的信息,这样,当用户在网站页面之间跳转时,存储的 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购物车类
代码如下 | 复制代码 |
<?php /* /* /* /* //如果减少后,数量为0,则把这个商品删掉 /* /* $sum = 0; /* /* |
代码如下 | 复制代码 |
<?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; } ?> |
相关文章
PHP session_start()很慢问题分析与解决办法
本文章来给各位同学介绍一下关于PHP session_start()很慢问题分析与解决办法,希望碰到此问题的同学可进入参考。 最近在做东西的时候发现一个问题 有一个接口挂...2016-11-25- php 获取用户IP与IE信息程序 function onlineip() { global $_SERVER; if(getenv('HTTP_CLIENT_IP')) { $onlineip = getenv('HTTP_CLIENT_IP');...2016-11-25
- php简单用户登陆程序代码 这些教程很对初学者来讲是很有用的哦,这款就下面这一点点代码了哦。 <center> <p> </p> <p> </p> <form name="form1...2016-11-25
- 一个用Javascript检测用户输入密码强度的效果代码,以下代码主要是从以下四个方面检测用户输入的密码的强度的,有兴趣的朋友可以自己添加或修改成自己想要的形式! 1. 如果输入的密码位数少于5位,那么就判定为弱。 2. 如果...2015-10-23
- 当来访者浏览器语言是中文就进入中文版面,国外的用户默认浏览器不是中文的就跳转英文页面。 <?php $lan = substr( $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- 【问题描述】:同一用户在同一时间多次登录如果不能检测出来,是危险的。因为,你无法知道是否有其他用户在登录你的账户。如何禁止同一用户多次登录呢? 【解决方案】 (1) 每次登录,身份认证成功后,重新产生一个session_id。 s...2015-11-24
- 这篇文章主要为大家详细介绍了vue实现用户登录切换,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-04-22
- 这篇文章主要介绍了C#中的session用法 ,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下...2020-06-25
Python3使用Selenium获取session和token方法详解
这篇文章主要介绍了Python3使用Selenium获取session和token方法详解,需要的朋友可以参考下...2021-02-17- 这是注册程序是一款当用户输入完用户名是,就会自动去数据库中查询用户要注册的用户名是否己经被注册了,如果是返回提示否则提示可以注册。 conn.php文件 代...2016-11-25
- 这篇文章主要给大家介绍了关于微信小程序用户授权最佳实践的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-05-08
- session和cookie是网站浏览中较为常见的两个概念,也是比较难以辨析的两个概念,但它们在点击流及基于用户浏览行为的网站分析中却相当关键。基于网上一些文章和资料的参阅,及作者个人的应用体会,对这两个概念做一个简单的阐述...2013-09-11
- session在php中是一个非常重要的东西,像我们用户登录一般都使用到session这个东西,相对于cookie来说session 要安全很多,同时我们购物车经常使用session来做临时的记录保存哦。使用session保存页面登录信息1、数据库连接...2015-10-21
- cookie 的用途之一是存储用户在特定网站上的密码和 id。另外,也用于存储起始页的首选项。在提供个人化查看的网站上,将要求阁下的网络浏览器利用阁下计算机硬驱上的少量...2016-11-25
- 这篇文章主要介绍了Vue使用axios引起的后台session不同操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-08-14
- 注册页面是大多数网站必备的页面,所以很有必要对自己的注册页面做些精心的设计。下面三张图,第一张是注册的展示页面,第二张思维导图就一个简单的逻辑,第三张是通过firebug查看调用的JS文件。 一、给每个输入框写下说明在...2015-11-24
- 知识归纳因为MySQL是使用User和Host两个字段来确定用户身份的,这样就带来一个问题,就是一个客户端到底属于哪个host。 如果一个客户端同时匹配几个Host,对用户的确定将按照下面的优先级来排 基本观点越精确的匹配越优先...2015-11-08
- PHP的session功能,一直为许多的初学者为难。就连有些老手,有时都被搞得莫名其妙。本文,将这些问题,做一个简单的汇总,以便大家查阅。 1. 错误提示 引用 代...2016-11-25
- 这篇文章主要介绍了sqlserver添加sa用户和密码的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-05-07