推薦:《PHP視頻教程》
PHP實現簡單的驗證碼功能機制
網站的安全性是開發者不可忽視的壹個問題,目前使用最多的壹種可以提高網站安全性的方法就是使用驗證碼功能機制,有的僅僅使用壹個幾位數字字母混亂的驗證碼,有的進行手機發送短信進行驗證,有的使用郵箱發送郵件進行驗證,但是這個驗證碼功能機制是如何實現的呢?下面就為大家詳細解釋驗證碼功能機制的實現思路以及簡單的實現方法。
1、驗證碼功能機制實現思路
① 常規的驗證碼實現:
a、產生壹張png的圖片
b、為圖片設置背景色
c、設置字體顏色和樣式
d、產生4位數的隨機的驗證碼
e、把產生的每個字符調整旋轉角度和位置畫到png圖片上
f、加入噪點和幹擾線防止註冊機器分析原圖片來惡意註冊
g、輸出圖片
h、釋放圖片所占內存
i、將驗證碼保存到session或是數據庫
j、將和輸入的驗證碼進行對比
② 短信(郵箱)驗證碼機制:
a、產生4-6位數的隨機的驗證碼
b、把產生的每個字符保存到session或是數據庫
c、將驗證碼發送到用戶的手機(郵箱)
d、用戶在規定時間內進行輸入
e、將驗證碼從session或是數據庫中取出
f、將和輸入的驗證碼進行對比驗證
2、簡單的實現驗證碼功能機制
① 新建captcha.php,寫入以下代碼
<?php
/**
* =======================================
* Created by WeiBang Technology.
* User: Wei ZhiHua
* Date: 2016/10/12 0020
* Time: 下午 4:14
* Power: 實現驗證碼功能
* =======================================
*/
//開啟session
session_start();
//創建壹個大小為 100*30 的驗證碼
$image = imagecreatetruecolor(100, 30);
$bgcolor = imagecolorallocate($image, 255, 255, 255);
imagefill($image, 0, 0, $bgcolor);
$captch_code = '';
for ($i = 0; $i < 4; $i++) {
$fontsize = 6;
$fontcolor = imagecolorallocate($image, rand(0, 120), rand(0, 120), rand(0, 120));
$data = 'abcdefghijkmnpqrstuvwxy3456789';
$fontcontent = substr($data, rand(0, strlen($data) - 1), 1);
$captch_code .= $fontcontent;
$x = ($i * 100 / 4) + rand(5, 10);
$y = rand(5, 10);
imagestring($image, $fontsize, $x, $y, $fontcontent, $fontcolor);
}
//就生成的驗證碼保存到session
$_SESSION['authcode'] = $captch_code;
//在圖片上增加點幹擾元素
for ($i = 0; $i < 200; $i++) {
$pointcolor = imagecolorallocate($image, rand(50, 200), rand(50, 200), rand(50, 200));
imagesetpixel($image, rand(1, 99), rand(1, 29), $pointcolor);
}
//在圖片上增加線幹擾元素
for ($i = 0; $i < 3; $i++) {
$linecolor = imagecolorallocate($image, rand(80, 220), rand(80, 220), rand(80, 220));
imageline($image, rand(1, 99), rand(1, 29), rand(1, 99), rand(1, 29), $linecolor);
}
//設置頭
header('content-type:image/png');
imagepng($image);
imagedestroy($image);
>② 新建form.php,寫入以下代碼