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

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

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

これまでは PHP を使って背景なし、または背景を同じ色の検証コードを生成していましたが、このような検証は機械が認識しやすいため、背景付きのグラフィックの検証コードを生成する例をいくつか紹介します。

1. PNG画像を生成します
2. 画像の背景色を設定します
3. フォントの色とスタイルを設定します
4. 4桁のランダムな確認コードを生成します
5.生成された各キャラクターの回転角度や位置を調整して、PNG画像上に描画します
6. ノイズと干渉ラインを追加して、登録マシンが元の画像を分析して悪意のある登録を行わないようにする
7. 画像を出力します
8. 写真で占められていたメモリを解放します
authcode.php ファイル

コード

コードは次のとおりです コードをコピー
session_start();
ヘッダー ( 'Content-type: image/png' );
//画像を作成します
$im = imagecreate($x=130,$y=45);
$bg = imagecolorallocate($im,rand(50,200),rand(0,155),rand(0,155)); //imagecolorallocate() の最初の呼び出しは、パレットベースの画像を背景色で塗りつぶします
$fontColor = imageColorAllocate ($im, 255, 255, 255); // フォントの色
$fontstyle = 'rock.ttf'; //フォント スタイル。これは、authcode.php ファイルと同じディレクトリにあります。ここで他のフォント スタイルを置き換えることができます。 //ランダムな文字を生成します
for($i = 0; $i < 4; $i ++) {
$ randasciinumarray $ randasciinum                                                                                                                                     Imagettftext($im,30,rand(0,20)-rand(0,25),5+$i*30,rand(30,35),$fontColor,$fontstyle,$randStr);
$authcode }
$ _Session ['Authcode'] = $ Randfourstr // ユーザーが入力した検証コードと比較するユーザー
; //干渉線
for ($i=0;$i<8;$i++){
$lineColor = imagecolorallocate($im,rand(0,255),rand(0,255),rand(0,255));
イメージライン ($im,rand(0,$x),0,rand(0,$x),$y,$lineColor);
}
//干渉点
for ($i=0;$i<250;$i++){
imagesetpixel($im,rand(0,$x),rand(0,$y),$fontColor);
}
imagepng($im);
imagedestroy($im); ?>


例 2

•新しい PHP ファイル captcha_code_file.php を作成します

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

//まずセッションを開きます
セッション開始(); //フロントに表示される認証コードの長さと幅を定義します
$image_width = 120; $image_height = 40; $characters_on_image = 6; $font = './monofont.ttf';
// CAPTCHA コードで使用できる文字
//混乱を招く文字 (l 1 と i など) を避けてください
$possible_letters = '23456789bcdfghjkmnpqrstvwxyz'; $ランダムドット = 10; $random_lines = 30; $captcha_text_color="0x142864"; $captcha_noice_color = "0x142864"; //検証コードを生成する文字列を定義します
$コード = '';
$i = 0; while ($i < $characters_on_image) {
$code .= substr($possible_letters, mt_rand(0, strlen($possible_letters)-1), 1); $i++; }

$font_size = $image_height * 0.75; $image = @imagecreate($image_width, $image_height);
/* ここで背景、テキスト、ノイズの色を設定します */
$background_color = imagecolorallocate($image, 255, 255, 255);
$arr_text_color = hexrgb($captcha_text_color); $text_color = imagecolorallocate($image, $arr_text_color['red'],
$arr_text_color['green']、$arr_text_color['blue']);
$arr_noice_color = hexrgb($captcha_noice_color); $image_noise_color = imagecolorallocate($image, $arr_noice_color['red'],
$arr_noice_color['green']、$arr_noice_color['blue']);
/* バックグラウンドでドットをランダムに生成します */
for( $i=0; $i<$random_dots; $i++ ) {
imagefilledellipse($image, mt_rand(0,$image_width),
mt_rand(0,$image_height), 2, 3, $image_noise_color); }

/* 画像の背景に線をランダムに生成 */
for( $i=0; $i<$random_lines; $i++ ) {
imageline($image, mt_rand(0,$image_width), mt_rand(0,$image_height),
mt_rand(0,$image_width)、mt_rand(0,$image_height)、$image_noise_color); }

/* テキスト ボックスを作成し、そこに 6 文字のコードを追加します */
$textbox = imagettfbbox($font_size, 0, $font, $code); $x = ($image_width - $textbox[4])/2; $y = ($image_height - $textbox[5])/2; imagettftext($image, $font_size, 0, $x, $y, $text_color, $font, $code);
/* ページの HTML ページにキャプチャ画像を表示 */
header('Content-Type: image/jpeg');// ブラウザー ウィンドウに表示される画像タイプを定義します
imagejpeg($image);//画像を表示します
imagedestroy($image);//イメージインスタンスを破棄します
// セッションをセットアップして検証を実行します
$_SESSION['6_letters_code'] = $code;
関数 hexrgb ($hexstr)
{
$int = hexdec($hexstr);
return array("red" => 0xFF & ($int >> 0x10),
"緑" => 0xFF & ($int >> 0x8)、
"青" => 0xFF & $int); }

確認コードページindex.phpを表示

セッション開始(); if(isset($_REQUEST['送信'])){
// サーバー側の検証をチェックするコード
If(empty($_SESSION['6_letters_code'] ) ||
strcasecmp($_SESSION['6_letters_code'], $_POST['6_letters_code']) != 0)
{
$msg="入力した確認コードが間違っています。再入力してください。"; }その他{
echo "入力した内容は正しいです!"; // キャプチャの検証は正しいです
最終コードを実行します。 }
}
?>