ホームページ  >  記事  >  バックエンド開発  >  php で動的ランダム検証コードを作成する、php 動的検証コード_PHP チュートリアル

php で動的ランダム検証コードを作成する、php 動的検証コード_PHP チュートリアル

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

phpは動的ランダム検証コードを生成します、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);
画像文字列($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));
画像文字列($_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['コード'] = $_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);
//破壊
画像破壊($_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');
?>


<頭>
    <メタ文字セット="UTF-8">
    確認コード
   


   

       

           

               
验证码:                

           

       
   



显示如下:

2)创建生産验证码图片页面

创建codeimg.phpはverification-code.php html代码里のimg提供验证码图片

最初に codeimg.php页面开启セッションに参加する必要があります;

次回、将我们封装好的global.func.php全局関数数库導入来来;

最後に、运行_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页面も开启セッションに存在する必要があります;

次に、提示交換コードの方式を設定します。ここでは get 方式で提示し、action=verification の時点で提示が成功します。

最後に、テスト関数を作成しました。原理は、ゲスト端末のユーザーハンドリングのテストコードが一致するかどうかです。ここには、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('認証コードが合格しました!');
}
}
?>


<頭>
<メタ文字セット="UTF-8">
確認コード






                                                                                              
検証コード: &lt; dd&gt;&lt; input type = "submit" class = "submit" value = "balification" /&gt;&lt; /dd&gt;
                                                                                                





3. 確認コードの画像をクリックして確認コードを更新します

上記の確認コードを更新したい場合は、確認コードの画像をクリックして確認コードを更新する codeimg.js 関数を作成してページを更新する必要があります。

コードをコピーします

コードは次のとおりです: window.onload = function () {
var code = document.getElementById('codeimg');//id を使用して HTML 内の img タグを検索します
Code.onclick = function () {//ラベルにクリック イベントを追加します
This.src='codeimg.php?tm='+Math.random();//時間を変更して codeimg.php にリダイレクトします
}; }



次に、それをverification-code.phpのHTMLコードヘッドに<リンク>します。

http://www.bkjia.com/PHPjc/957115.html

www.bkjia.com

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