$_SESSION["vcode"] = $vcode;
贊皇網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)公司!從網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)公司等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。創(chuàng)新互聯(lián)公司從2013年成立到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)公司。
驗(yàn)證碼的值就在 $_SESSION["vcode"] 里面。
?驗(yàn)證碼功能機(jī)制實(shí)現(xiàn)思路
常規(guī)的驗(yàn)證碼實(shí)現(xiàn):
a、產(chǎn)生一張png的圖片
b、為圖片設(shè)置背景色
c、設(shè)置字體顏色和樣式
d、產(chǎn)生4位數(shù)的隨機(jī)的驗(yàn)證碼
e、把產(chǎn)生的每個字符調(diào)整旋轉(zhuǎn)角度和位置畫到png圖片上
f、加入噪點(diǎn)和干擾線防止注冊機(jī)器分析原圖片來惡意注冊
g、輸出圖片
h、釋放圖片所占內(nèi)存
i、將驗(yàn)證碼保存到session或是數(shù)據(jù)庫
j、將和輸入的驗(yàn)證碼進(jìn)行對比
短信(郵箱)驗(yàn)證碼機(jī)制:
a、產(chǎn)生4-6位數(shù)的隨機(jī)的驗(yàn)證碼
b、把產(chǎn)生的每個字符保存到session或是數(shù)據(jù)庫
c、將驗(yàn)證碼發(fā)送到用戶的手機(jī)(郵箱)
d、用戶在規(guī)定時間內(nèi)進(jìn)行輸入
e、將驗(yàn)證碼從session或是數(shù)據(jù)庫中取出
f、將和輸入的驗(yàn)證碼進(jìn)行對比驗(yàn)證
1.?新建code.php驗(yàn)證碼生成文件
在此之前必須打開php的GD庫,修改php.ini文件的配置,取消extension=php_gd2.dll前面的分號。代碼如下:
?php
session_start();
//生成驗(yàn)證碼圖片
Header("Content-type: image/PNG");
$im = imagecreate(44,18);
$back = ImageColorAllocate($im, 245,245,245);
imagefill($im,0,0,$back); //背景
srand((double)microtime()*1000000);
//生成4位數(shù)字
for($i=0;$i4;$i++){
$font = ImageColorAllocate($im, rand(100,255),rand(0,100),rand(100,255));
$authnum=rand(1,9);
$vcodes.=$authnum;
imagestring($im, 5, 2+$i*10, 1, $authnum, $font);
}
for($i=0;$i100;$i++) //加入干擾象素
{
$randcolor = ImageColorallocate($im,rand(0,255),rand(0,255),rand(0,255));
imagesetpixel($im, rand()p , rand()0 , $randcolor);
}
ImagePNG($im);
ImageDestroy($im);
$_SESSION['Checknum'] = $vcodes;
?
2. 顯示驗(yàn)證碼圖片
在需要顯示驗(yàn)證碼的頁面中加入
input type="text" name="passcode"
img src="code.php"
3.判斷并獲取驗(yàn)證碼的值
驗(yàn)證碼是通過第一步驟代碼中的$_SESSION['Checknum'] = $vcodes;賦的值,所以驗(yàn)證碼的值存在$_SESSION['Checknum']當(dāng)中。在驗(yàn)證頁面,使用以下代碼,
...
session_start();//啟動會話
$code=$_POST["passcode"];
if( $code == $_SESSION["Checknum"])
{...}即可完成驗(yàn)證碼登錄。
運(yùn)行截圖:
望采納,謝謝
PHP驗(yàn)證程序,假設(shè)數(shù)據(jù)庫存儲的是用戶名和 md5 加密后的密碼:
// 表單提交后...
$posts = $_POST;
// 清除一些空白符號
foreach ($posts as $key = $value)
{
$posts[$key] = trim($value);
}
$password = md5($posts["password"]);
$username = $posts["username"];
$query = "SELECT `username` FROM `user` WHERE `password` = '$password'";
// 取得查詢結(jié)果
$userInfo = $DB-getRow($query);
if (!empty($userInfo))
{
if ($userInfo["username"] == $username)
{
// 當(dāng)驗(yàn)證通過后,啟動 session
session_start();
// 注冊登陸成功的 admin 變量,并賦值 true
$_session["admin"] = true;
}
else
{
die("用戶名密碼錯誤");
}
}
else
{
die("用戶名密碼錯誤");
}
我們在需要用戶驗(yàn)證的頁面啟動 session,判斷是否登陸:
// 防止全局變量造成安全隱患
$admin = false;
// 啟動會話,這步必不可少
session_start();
// 判斷是否登陸
if (isset($_SESSION["admin"]) $_session["admin"] === true)
{
echo "您已經(jīng)成功登陸";
}
else
{
// 驗(yàn)證失敗,將 $_session["admin"] 置為 false
$_session["admin"] = false;
die("您無權(quán)訪問");
}
?
當(dāng)前題目:php數(shù)據(jù)庫查詢驗(yàn)證碼,php自動識別驗(yàn)證碼
當(dāng)前鏈接:http://jinyejixie.com/article4/dssocoe.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器、靜態(tài)網(wǎng)站、網(wǎng)站設(shè)計(jì)公司、網(wǎng)站排名、定制網(wǎng)站、微信公眾號
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)