做一個後台登陸需要用到校驗碼,前台的用戶跟蹤需要用到SessionID,當然,默認的PHP開啟了Session以後就有了一個SessionID,但是我需要自己的,並且能夠存儲進數據庫,那麼我就嘗試了一下,構造了以下的函數。
/****** 產生Session ID ******/
基本的思路: 是把當前微秒的時間獲取, 然後產生以個隨機數字, 把隨機數字和當前時間相加後加密一下, 最後再截取需要的長度
/*
函數名稱:create_sess_id()
函數作用:產生以個隨機的會話ID
參 數:$len: 需要會話字符串的長度,默認為32位,不要低於16位
返 回 值:返回會話ID
函數heiyeluren
*/
function create_sess_id($len=32)
{
// 校驗提交的長度是否合法
if( !is_numeric($len) || ($len>32) || ($len<16)) { return; }
// 獲取當前時間的微秒
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;
}
/****** 產生校驗碼 ******/
思路: 這個思路比較簡單,因為考慮獨一無二和隨機性,我們的校驗碼就Session ID裡面截取一段字符串就可以了,因為我們的SessionID是充分考慮了獨一無二的。
/*
函數名稱:create_check_code()
函數作用:產生以個隨機的校驗碼
參 數:$len: 需要校驗碼的長度, 請不要長於16位,缺省為4位
返 回 值:返回指定長度的校驗碼
函數heiyeluren
*/
function create_check_code($len=4)
{
if ( !is_numeric($len) || ($len>6) || ($len<1)) { return; }
$check_code = substr(create_sess_id(), 16, $len );
return strtoupper($check_code);
}
/****** 生成校驗碼的圖片 ******/
這個就是一些比較簡單的PHP圖像編程的東西了,我作的圖片和簡單。
/*
函數名稱:create_check_image()
函數作用:產生一個校驗碼的圖片
參 數:$check_code: 校驗碼字符串,一般由create_check_code()函數來獲得