CAPTCHAとは、「Completely Automated Public Turing test to Tell Computers and Humans Apart」の略で、ユーザーがコンピュータであるか人間であるかを識別する公開された完全自動プログラムです。これにより、悪意のあるパスワードのクラッキング、チケット詐欺、フォーラムのフラッディングが防止され、ハッカーが特定のプログラムを使用して特定の登録ユーザーが継続的にログイン試行することを効果的に阻止できます。実際、確認コードの使用は、多くのユーザーにとって一般的な方法です。この機能は比較的簡単な方法で実装されています。
この質問はコンピューターによって生成および判断できますが、答えることができるのは人間だけです。コンピュータは CAPTCHA の質問に答えることができないため、質問に答えるユーザーは人間であると考えられます。
PHP5 では、動的な画像の処理が以前よりもはるかに簡単になりました。 PHP5 には、php.ini ファイルに GD 拡張機能パッケージが含まれています。通常に使用するには、GD 拡張機能パッケージの対応するコメントを削除するだけで済みます。 PHP5 に含まれる GD ライブラリは、アップグレードされた GD2 ライブラリであり、トゥルー カラー画像処理をサポートするいくつかの便利な JPG 関数が含まれています。
一般的に生成されたグラフィックスは PHP のドキュメント形式で保存されますが、動的なグラフィックスは HTML の画像挿入メソッド SRC を通じて直接取得できます。たとえば、確認コード、ウォーターマーク、サムネイルなどです。
1). 生成したい MIME タイプをブラウザーに伝えるヘッダーを設定します。
2). 画像領域を作成し、その後のすべての操作はこの画像領域に基づいて行われます。
4). 背景にグラフィックの輪郭を描いてテキストを入力します。
7). 他のページから画像を呼び出します。
imagecreatetruecolor() は、サイズ x_size および y_size の黒い画像を表す画像識別子を返します。構文: resource imagecreatetruecolor ( int $width , int $height )
カラーフィラーが必要です。imagecolorallocate -- 画像に色を割り当てます。構文: int imagecolorallocate ( resource $image , int $red , int $blue )
この青色を背景に塗りつぶします。 imagefill -- 領域の塗りつぶし 構文: bool imagefill ( resource $image , int $x , int $color )
imageline() は、イメージ画像上に座標 x1,y1 から x2,y2 (画像の左上隅が 0,0) までの線分をカラー color を使用して描画します。構文: bool imageline ( resource $image , int $x1 , int $y1 , int $x2 , int $y2 , int $color )
imagestring() は、col color を使用して、文字列 s を image で表される画像の x、y 座標に描画します (これは文字列の左上隅の座標であり、画像全体の左上隅は 0 です)。 0)。フォントが 1、2、3、4、または 5 の場合は、内蔵フォントが使用されます。構文: bool imagestring ( resource $image , int $font , int $x , int $y , string $s , int $col )
imagepng() GD イメージ ストリーム (画像) を PNG 形式で標準出力 (通常はブラウザ) に出力するか、ファイル名が指定されている場合はファイルに出力します。構文: bool imagepng ( resource $image [, string $filename ] )
imagedestroy() は画像に関連付けられたメモリを解放します。構文: bool imagedestroy ( resource $image )
imagedestroy($im);
他のページで作成したグラフィックを呼び出します(html)
サンプルコードは次のとおりです:
コードをコピー
//最初のステップはファイルの MIME タイプを設定することです
header('Content-Type: image/png;');
//2 番目のステップは、グラフィックス領域と画像の背景を作成することです
$im = imagecreatetruecolor(200,200);
// 3 番目のステップは、空白の画像領域に塗りつぶされた背景を描画することです
$blue = imagecolorallocate($im,0,102,255);
imagefill($im,0,0,$blue);
//ステップ 4、青い背景に行やテキストなどを入力します
$white = imagecolorallocate($im,255,255,255);
イメージライン($im,0,0,200,200,$white);
イメージライン($im,200,0,0,200,$white);
imagestring($im,5,66,20,'Jing.Whale',$white);
//ステップ 5、最終グラフィックを出力します
imagepng($im);
//ステップ 6、すべてのリソースをクリアしたいです
イメージデストロイ($im)
?>
コードをコピー
表示効果:
画像
2. 動的検証コードを作成する
添付: コードソースアドレス https://github.com/cnblogs-/php-captcha
1. 確認コードを含む写真を作成し、背景をぼかします
ランダム コードは 16 進数を使用します。ぼかした背景とは、画像の背景に線や雪の結晶などを追加することを意味します。
1) ランダムコードを作成します
for ($i=0;$i<$_rnd_code;$i++) {
$_nmsg .= dechex(mt_rand(0,15));
}
string dechex (int $number) は、指定された数値パラメーターの 16 進表現を含む文字列を返します。
2) セッションに保存
$_SESSION['コード'] = $_nms
3)画像を作成します
コードをコピー
//画像を作成します
$_img = imagecreatetruecolor($_width,$_height);
//ホワイト
$_white = imagecolorallocate($_img,255,255,255);
//パディング
imagefill($_img,0,0,$_white);
if ($_flag) {
//黒、ボーダー
$_black = imagecolorallocate($_img,0,0,0);
imagerectangle($_img,0,0,$_width-1,$_height-1,$_black);
}
コードをコピー
4) 背景をぼかす
コードをコピー
//ランダムに6本の線を描きます
for ($i=0;$i<6;$i++) {
$_rnd_color = imagecolorallocate($_img,mt_rand(0,255),mt_rand(0,255),mt_rand(0,255));
imageline($_img,mt_rand(0,$_width),mt_rand(0,$_height),mt_rand(0,$_width),mt_rand(0,$_height),$_rnd_color);
}
//ランダムな雪の結晶
for ($i=0;$i<100;$i++) {
$_rnd_color = imagecolorallocate($_img,mt_rand(200,255),mt_rand(200,255),mt_rand(200,255));
imagestring($_img,1,mt_rand(1,$_width),mt_rand(1,$_height),'*',$_rnd_color);
}
コードをコピー
5) 出力と破壊
コードをコピー
//確認コードを出力する
for ($i=0;$i
$_rnd_color = imagecolorallocate($_img,mt_rand(0,100),mt_rand(0,150),mt_rand(0,200));
imagestring($_img,5,$i*$_width/$_rnd_code+mt_rand(1,10),mt_rand(1,$_height/2),$_SESSION['code'][$i],$_rnd_color);
}
//出力画像
header('Content-Type: image/png');
imagepng($_img);
//破壊
imagedestroy($_img);
コードをコピー
これを global.func.php グローバル関数ライブラリにカプセル化し、呼び出しやすいように関数名を _code() にします。関数の柔軟性を高めるために、4 つのパラメーター $_width、$_height、$_rnd_code、$_flag を設定します。
* @param int $_width 検証コードの長さ: 6 桁が必要な場合は 75+50 が推奨され、8 桁が必要な場合は 75+50+50 が推奨されます。
* @param int $_height 認証コードの高さ
* @param int $_rnd_code 確認コードの桁数
* @param bool $_flag 検証コードに境界線が必要かどうか: 境界線ありの true、境界線なしの false (デフォルト)
カプセル化されたコードは次のとおりです:
コードをコピー
/**
* [認証コード] (C)2015-2100 jingwhale.
*
* これはフリーウェアです
* $Id: global.func.php 2015-02-05 20:53:56 jingwhale$
*/
/**
* _code()は認証コード関数です
* @アクセス公開
* @param int $_width 検証コードの長さ: 6 桁が必要な場合は 75+50 が推奨され、8 桁が必要な場合は 75+50+50 が推奨されます。
* @param int $_height 認証コードの高さ
* @param int $_rnd_code 確認コードの桁数
* @param bool $_flag 検証コードに境界線が必要かどうか: 境界線ありの true、境界線なしの false (デフォルト)
* @return void この関数は実行後に検証コードを生成します
*/
function _code($_width = 75,$_height = 25,$_rnd_code = 4,$_flag = false) {
//ランダムコードを作成します
for ($i=0;$i<$_rnd_code;$i++) {
$_nmsg .= dechex(mt_rand(0,15));
}
//セッション中に保存
$_SESSION['code'] = $_nmsg;
//画像を作成します
$_img = imagecreatetruecolor($_width,$_height);
//ホワイト
$_white = imagecolorallocate($_img,255,255,255);
//塗りつぶし
imagefill($_img,0,0,$_white);
if ($_flag) {
//黒、ボーダー
$_black = imagecolorallocate($_img,0,0,0);
Imagerectangle($_img,0,0,$_width-1,$_height-1,$_black);
}
//すぐに6本の線を描きます
for ($i=0;$i<6;$i++) {
$_rnd_color = imagecolorallocate($_img,mt_rand(0,255),mt_rand(0,255),mt_rand(0,255));
画像ライン($_img,mt_rand(0,$_width),mt_rand(0,$_height),mt_rand(0,$_width),mt_rand(0,$_height),$_rnd_color);
}
//雪の結晶が続きます
for ($i=0;$i<100;$i++) {
$_rnd_color = imagecolorallocate($_img,mt_rand(200,255),mt_rand(200,255),mt_rand(200,255));
画像文字列($_img,1,mt_rand(1,$_width),mt_rand(1,$_height),'*',$_rnd_color);
}
//検証コードを出力します
for ($i=0;$i
$_rnd_color = imagecolorallocate($_img,mt_rand(0,100),mt_rand(0,150),mt_rand(0,200));
imagestring($_img,5,$i*$_width/$_rnd_code+mt_rand(1,10),mt_rand(1,$_height/2),$_SESSION['code'][$i],$_rnd_color);
}
//出力画像
header('Content-Type: image/png');
imagepng($_img);
//破壊
imagedestroy($_img);
}
?>
コードをコピー
2. 検証メカニズムを作成する
PHP 検証ページを作成し、セッションを通じて検証コードが一貫しているかどうかを確認します。
1)verification-code.php検証ページを作成します
コードをコピー
/**
* [認証コード] (C)2015-2100 jingwhale.
*
* これはフリーウェアです
* $Id:verification-code.php 2015-02-05 20:53:56 jingwhale$
*/
//文字セットエンコーディングを設定します
header('Content-Type: text/html; charset=utf-8');
?>
確認コード
D & lt; dd & gt; 入力タイプ = "テキスト" クラス = "コード" /& gt; src = "codeimg.php" /& &; / dd>
D & lt; dd & gt; 入力タイプ = "送信" 値 = "検証" /& gt;
ボディ>