ホームページ >バックエンド開発 >PHPチュートリアル >PHP は動的ランダム検証コード機構を実装します_PHP チュートリアル

PHP は動的ランダム検証コード機構を実装します_PHP チュートリアル

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

phpは動的ランダム検証コードメカニズムを実装します

CAPTCHAとは、「Completely Automated Public Turing test to Tell Computers and Humans Apart」の略で、ユーザーがコンピュータであるか人間であるかを識別する公開された完全自動プログラムです。これにより、悪意のあるパスワードのクラッキング、チケット詐欺、フォーラムのフラッディングが防止され、ハッカーが特定のプログラムを使用して特定の登録ユーザーが継続的にログイン試行することを効果的に阻止できます。実際、確認コードの使用は、多くのユーザーにとって一般的な方法です。この機能は比較的簡単な方法で実装されています。
この質問はコンピューターによって生成および判断できますが、答えることができるのは人間だけです。コンピュータは CAPTCHA の質問に答えることができないため、質問に答えるユーザーは人間であると考えられます。
PHP での動的検証コードの生成は、PHP の画像処理に基づいています。まず、PHP の画像処理について説明します。
1.php画像処理入門
PHP5 では、動的な画像の処理が以前よりもはるかに簡単になりました。 PHP5 には、php.ini ファイルに GD 拡張機能パッケージが含まれています。通常に使用するには、GD 拡張機能パッケージの対応するコメントを削除するだけで済みます。 PHP5 に含まれる GD ライブラリは、アップグレードされた GD2 ライブラリであり、トゥルー カラー画像処理をサポートするいくつかの便利な JPG 関数が含まれています。
一般的に生成されたグラフィックスは PHP のドキュメント形式で保存されますが、動的なグラフィックスは HTML の画像挿入メソッド SRC を通じて直接取得できます。たとえば、確認コード、ウォーターマーク、サムネイルなどです。
画像を作成するための一般的なプロセス:
1). 生成したい MIME タイプをブラウザーに伝えるヘッダーを設定します。
2). 画像領域を作成し、その後のすべての操作はこの画像領域に基づいて行われます。
3).空白の画像領域に塗りつぶされた背景を描画します。
4). 背景にグラフィックの輪郭を描いてテキストを入力します。
5).最終的なグラフィックを出力します。
6) すべてのリソースをクリアします。
7). 他のページから画像を呼び出します。
最初のステップは、ファイルの MIME タイプと出力タイプを設定することです。出力タイプを画像ストリームに変更します。
header('Content-Type: image/png;');
一般的に生成される画像は、png、jpeg、gif、wbmp です
2 番目のステップは、グラフィックス領域と画像の背景を作成することです
imagecreatetruecolor() は、サイズ x_size および y_size の黒い画像を表す画像識別子を返します。構文: resource imagecreatetruecolor ( int $width , int $height )
$im = imagecreatetruecolor(200,200);
3番目のステップは、空白の画像領域に塗りつぶされた背景を描画することです
カラーフィラーが必要です。imagecolorallocate -- 画像に色を割り当てます。構文: int imagecolorallocate ( resource $image , int $red , int $blue )
$blue = imagecolorallocate($im,0,102,255);
この青色を背景に塗りつぶします。 imagefill -- 領域の塗りつぶし 構文: bool imagefill ( resource $image , int $x , int $color )
imagefill($im,0,0,$blue);
4番目のステップは、青色の背景に線やテキストなどを入力することです
カラーフィラー
$white = imagecolorallocate($im,255,255,255);
2つの線分を描画します: imageline
imageline() は、イメージ画像上に座標 x1,y1 から x2,y2 (画像の左上隅が 0,0) までの線分をカラー color を使用して描画します。構文: bool imageline ( resource $image , int $x1 , int $y1 , int $x2 , int $y2 , int $color )
イメージライン($im,0,0,200,200,$white);
イメージライン($im,200,0,0,200,$white);
文字列を水平方向に描画します: imagestring
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 )
画像文字列($im,5,66,20,'ジンクジラ',$white);
ステップ 5、最終グラフィックを出力します
imagepng() GD イメージ ストリーム (画像) を PNG 形式で標準出力 (通常はブラウザ) に出力するか、ファイル名が指定されている場合はファイルに出力します。構文: bool imagepng ( resource $image [, string $filename ] )
imagepng($im);
ステップ 6、すべてのリソースをクリアしたいです
imagedestroy() は画像に関連付けられたメモリを解放します。構文: bool imagedestroy ( resource $image )
imagedestroy($im);
他のページで作成したグラフィックを呼び出します(html)
PHP で作成された画像
サンプルコードは次のとおりです:
コードをコピー
//最初のステップはファイルの 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" /& &;
D & lt; dd & gt; 入力タイプ = "送信" 値 = "検証" /& gt;
コードをコピー
次のように表示されます:
画像
2) 認証コード画像ページを作成します
codeimg.php を作成して、verification-code.php HTML コードに img の検証コード画像を提供します
まず codeimg.php ページでセッションを開く必要があります;
次に、カプセル化された global.func.php グローバル関数ライブラリを紹介します。
最後に、run_code();
コードをコピー
/**
* [認証コード] (C)2015-2100 jingwhale.
*
* これはフリーウェアです
* $Id: codeimg.php 2015-02-05 20:53:56 jingwhale$
 */
//オープンセッション
session_start();
//グローバル関数ライブラリ(カスタム)を導入します
dirname(__FILE__).'/includes/global.func.php';
が必要です
//確認コード関数を実行します。データベースの _code メソッドを通じて、検証コードのさまざまな属性を設定し、画像を生成します
_code(125,25,6,false);
?>
コードをコピー
画像
3) セッション検証メカニズムを作成する
まず、verification-code.php ページでもセッションを開く必要があります。
次に、検証コードを送信する方法を設計します。この記事は、action=verification の場合に送信されます。
最後に、検証関数を作成します。原則は、クライアント ユーザーが送信した検証コードが、サーバー codeimg.php のセッションの検証コードと一致するかどうかを確認することです。js ポップアップ関数 _alert_back() があります。また、それを func.php;
にカプセル化します。
verification-code.php の PHP コードを次のように変更します。
コードをコピー
/**
* [認証コード] (C)2015-2100 jingwhale.
*
* これはフリーウェアです
* $Id:verification-code.php 2015-02-05 20:53:56 jingwhale$
 */
//文字セットエンコーディングを設定します
header('Content-Type: text/html; charset=utf-8');
//オープンセッション
session_start();
//グローバル関数ライブラリ(カスタム)を導入します
dirname(__FILE__).'/includes/global.func.php';
が必要です
//確認コードを確認してください
if ($_GET['アクション'] == '検証') {
if (!($_POST['code'] == $_SESSION['code'])) {
_alert_back('確認コードが間違っています!');
}その他{
_alert_back('認証コードが合格しました!');
}
}
?>
確認コード
D & lt; dd & gt; 入力タイプ = "テキスト" クラス = "コード" /& gt; src = "codeimg.php" /& &;
D & lt; dd & gt; 入力タイプ = "送信" 値 = "検証" /& gt;
1
3. 認証コードの画像をクリックして認証コードを更新します
上記の確認コードを更新したい場合は、確認コードの画像をクリックして確認コードを更新する codeimg.js 関数を作成してページを更新する必要があります。
コードをコピー
window.onload = function() {
var code = document.getElementById('codeimg');// HTML 内の img タグを id で検索します
code.onclick = function () {//ラベルにクリック イベントを追加します
This.src='codeimg.php?tm='+Math.random();//時間を変更して codeimg.php にリダイレクトします
};
}
http://www.bkjia.com/PHPjc/954738.html
www.bkjia.com

tru​​ehttp://www.bkjia.com/PHPjc/954738.html技術記事 PHP は動的ランダム検証コードを実装しています。メカニズム検証コード (CAPTCHA) は、コンピュータと人間を区別するための完全に自動化されたパブリック チューリング テストです (コンピュータと人間を区別するための完全に自動化されたチューリング テストです...)
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。