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 "入力した内容は正しいです!";
// キャプチャの検証は正しいです 最終コードを実行します。
}
}
?>
| |