PHPの認証コード実装(w 3 schools推奨)
4795 ワード
本論文では,PHPのいくつかの利用可能な特性を用いて検証コード機能を実現した.このチュートリアルは非常に簡単で、変更可能なフォントを使用して検証コードピクチャを生成します.私たちが知っているように、検証コードはゴミコメントや自動コミットを避けるために使用されます.この認証コードプログラムのリソース:
ダウンロードアドレス
オンラインデモ
captcha_code_file.phpコード:
検証検証コードが正しいか間違っているかの方法検証コード画像の文字がSESSION変数に格納されています.検証するときは、SESSIONの値とユーザーが入力した値を比較する必要があります.$SESSION[6_letters_code]-認証コードが格納されている文字値$POST[6_letters_code]-ユーザーが入力した認証コードの内容です
index.phpコードにはHTML、CSS、Javascript and PHPコードが含まれています.
ダウンロードアドレス
オンラインデモ
captcha_code_file.phpコード:
<?php
session_start();
// :
$image_width = 120;
$image_height = 40;
$characters_on_image = 6;
$font = './monofont.ttf';
//
// 1 i
$possible_letters = '23456789bcdfghjkmnpqrstvwxyz';
$random_dots = 10;
$random_lines = 30;
$captcha_text_color="0x142864";
$captcha_noice_color = "0x142864";
$code = '';
$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;
function hexrgb ($hexstr) {
$int = hexdec($hexstr);
return array( "red" => 0xFF & ($int >> 0x10),
"green" => 0xFF & ($int >> 0x8),
"blue" => 0xFF & $int
);
}
?>
検証検証コードが正しいか間違っているかの方法検証コード画像の文字がSESSION変数に格納されています.検証するときは、SESSIONの値とユーザーが入力した値を比較する必要があります.$SESSION[6_letters_code]-認証コードが格納されている文字値$POST[6_letters_code]-ユーザーが入力した認証コードの内容です
index.phpコードにはHTML、CSS、Javascript and PHPコードが含まれています.
<?php session_start();
if(isset($_REQUEST['Submit'])){
//
if(empty($_SESSION['6_letters_code'] ) ||
strcasecmp($_SESSION['6_letters_code'], $_POST['6_letters_code']) != 0)
{
$msg=" !";
}else{
// ,
}
}
?>
<style type="text/css">
.table {
font-family:Arial, Helvetica, sans-serif;
font-size:12px;
color:#333;
background-color:#E4E4E4;
}
.table td {
background-color:#F8F8F8;
}
</style>
<form action="" method="post" name="form1" id="form1" >
<table width="400" border="0" align="center" cellpadding="5" cellspacing="1" class="table">
<?php if(isset($msg)){?>
<tr>
<td colspan="2" align="center" valign="top"><?php echo $msg;?></td>
</tr>
<?php } ?>
<tr>
<td align="right" valign="top"> :</td>
<td><img src="captcha_code_file.php?rand=<?php echo rand();?>" id='captchaimg'><br>
<label for='message'> :</label>
<br>
<input id="6_letters_code" name="6_letters_code" type="text">
<br>
? <a href='javascript: refreshCaptcha();'>here</a>
</p></td>
</tr>
<tr>
<td> </td>
<td><input name="Submit" type="submit" onclick="return validate();" value=" "></td>
</tr>
</table>
</form>
<script type='text/javascript'>
function refreshCaptcha()
{
var img = document.images['captchaimg'];
img.src = img.src.substring(0,img.src.lastIndexOf("?"))+"?rand="+Math.random()*1000;
}
</script>