因为工作的原因.要用到这个,所以研究了一下.主要思路是模拟COOKIES ..先往Cookies里面插入用户ID和一个SessionID,然后再往数据库中的sessions表里面插入SessionI......
因为工作的原因.要用到这个,所以研究了一下.
主要思路是模拟COOKIES ..先往Cookies里面插入用户ID和一个SessionID,然后再往数据库中的sessions表里面插入SessionID,和用户ID,如果打开论坛,系统会验证COOKIES的信息跟数据库中的信息是否一样,如果一样的话就可以实现自动登入..登入部份主要代码如下:
<?php //获取32位随机的SESSIONID //初始化各值 $Session_testId=create_sess_id(32); $SessionIp='192.168.0.100'; $cookie_path='/'; $cookieName='phpbb3_1w36a'; $userBrowserInfo= $_SERVER["HTTP_USER_AGENT"]; $userIpAdd=$_SERVER["REMOTE_ADDR"];
//获取表单的用户名和密码 $cmd_username=$_POST["username"]; $cmd_password=$_POST["password"]; //先跟CMS系统表验证,如果通过.查询相应用户名BBS用户表中的ID
$link=mysql_connect("localhost","root",""); mysql_select_db("cms"); $selectUid="select user_id from bbs_users where username='$cmd_username'"; $uidResult=mysql_query($selectUid); $userId=null; while($row1 = mysql_fetch_array($uidResult, MYSQL_NUM)) { $userId=$row1[0]; } //echo $userId; mysql_close($link);
//往Cookies里插入用户ID信息 setcookie($cookieName.'_u',$userId,time() 100000000,$cookie_path,$SessionIp,false); //往Cookies里插入SessionID信息 setcookie($cookieName.'_sid',$Session_testId,time() 100000000,$cookie_path,$SessionIp,false);
//往phpb_sessions表中插入Session信息 $link=mysql_connect("localhost","root",""); mysql_select_db("cms"); $sqlcommand="insert into bbs_sessions(session_id,session_user_id,session_last_visit,session_start,session_time,session_ip,session_browser,session_page)"; $sqlcommand.=" values('$Session_testId',$userId,'".time()."','".time()."','".time()."','$userIpAdd','$userBrowserInfo','index.php')";
//echo $sqlcommand;
mysql_query($sqlcommand); mysql_close($link);
//生成一个32位随机数 function create_sess_id($len=32) { // 获取当前时间的微秒 list($u, $s) = eXPlode(' ', microtime()); $time = (float)$u (float)$s; // 产生一个随机数 $rand_num = rand(100000, 999999); $rand_num = rand($rand_num, $time); mt_srand($rand_num); $rand_num = mt_rand(); // 产生SessionID $sess_id = md5( md5($time). md5($rand_num) ); // 截取指定需要长度的SessionID $sess_id = substr($sess_id, 0, $len); return $sess_id;
1/2 1 2 下一页 尾页 |