ホームページ  >  記事  >  バックエンド開発  >  PHP は、interference を使用して検証コード プログラムを生成します_PHP チュートリアル

PHP は、interference を使用して検証コード プログラムを生成します_PHP チュートリアル

WBOY
WBOYオリジナル
2016-07-13 17:10:091022ブラウズ

ここでは、比較的安全性の高い検証生成プログラムを紹介します。これには干渉線やその他のコンテンツが含まれる可能性があり、ユーザーがこのプログラムを使用して検証コードを特定することを効果的に阻止できます。

コードは次のとおりです コードをコピー

/*
※2011年3月11日作成
* プログラマー: xiaoyao、QQ:1045195056
入力値と$_SESSION['check_pic']の値を判断して検証します
*/
session_start();
関数 RandAscii($number){//$number は数字と文字の数を生成します
$arr=array('0','1','2','3','4','5','6','7','8','9',
'a'、'b'、'c'、'd'、'e'、'f'、'g'、'h'、'i'、'j'、'k'、'l'、'm ','n','o','p','q','r','s','t','w','v','u','x','y', 'z');
($i=1;$i<=$number;$i++) の場合
{
$rand= $rand.$arr[rand(0,35)];
}
$rand を返します;
}
$rand=RandAscii(4);

$_SESSION['check_pic']=$rand;//ランダムに生成された 4 つの番号が検証のためにセッションに割り当てられます。
$x=80;
$y=24;
$im=imagecreatetruecolor($x,$y);//画像を作成します
$bg=imagecolorallocate($im,255,255,255);//背景色を設定します
imagefill( $im,0,0,$bg);
$wh=imagecolorallocate($im,255,255,0);
$grey=imagecolorallocate($im,128,128,128);
$ yellow=imagecolorallocate($im,255,255,0);
$red=imagecolorallocate($im,0,255,0);
$foregroundArr = array(imagecolorallocate($im, rand(0, 20), rand(0, 20), rand(0, 20)),
imagecolorallocate($im, rand(0, 20), rand(0, 10), rand(245, 255)),
imagecolorallocate($im, rand(245, 255), rand(0, 20), rand(0, 10)),
imagecolorallocate($im, rand(245, 255), rand(0, 20), rand(245, 255))
);//ワードカラー配列
//境界線を描画します
$border = imagecolorallocate($im, 133, 153, 193);
imagerectangle($im, 0, 0, $x - 1, $y - 1, $border);

for($i=0;$i<10;$i++){ //干渉線を10本描画します
imageline($im,rand(0,60),2,rand(0,60),20,$ yellow);

}
for($j=0;$j<100;$j++){
imagesetpixel($im,rand()%76,rand()%20,$red);
}
//imagestring($im,6,15,8,$rand,$wh);//フォントサイズ 1-5
imagettftext($im, 14,rand(30, -30), 5, rand(15, 18) ,$foregroundArr[rand(0,3)], 'C:WindowsFontsArial.ttf',$rand[0]);
imagettftext($im, 14,rand(50, -50), 24, rand(15, 18),$foregroundArr[rand(0,3)], 'C:WindowsFontsArial.ttf',$rand[1]);
imagettftext($im, 14,rand(50, -50), 43, rand(15, 18) ,$foregroundArr[rand(0,3)], 'C:WindowsFontsArial.ttf',$rand[2]);
imagettftext($im, 14,rand(30, -30), 62, rand(15, 18),$foregroundArr[rand(0,3)], 'C:WindowsFontsArial.ttf',$rand[3]);

header("Content-type: image/jpeg");//出力画像
imagejpeg($im);
imagedestroy($im);
?>

メソッドの呼び出し

コードは次のとおりです コードをコピー
/*
※2011年3月11日作成
* プログラマー: xiaoyao、QQ:1045195056
入力値と$_SESSION['check_pic']の値を判断して検証します
*/
session_start();//セッションを開く
if(isset($_POST['check']))
{
if($_POST['check'])
{
if($_POST['check']==$_SESSION['check_pic'])
{
echo "確認コードは正しいです".$_SESSION['check_pic'];
}
それ以外
{
echo "検証コード エラー".$_SESSION['check_pic'];
}
}
}
?>
<フォームメソッド=ポストアクション="">




www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/629697.html技術記事ここでは、比較的安全性の高い検証生成プログラムを紹介します。このプログラムには干渉線やその他のコンテンツが含まれる可能性があり、ユーザーがこのプログラムを使用して検証コードを特定することを効果的に阻止できます。 コードは次のとおりです コードをコピーします...
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。