確認コードを生成する

WBOY
WBOYオリジナル
2016-07-25 08:44:001048ブラウズ
  1. require_once('string.func.php');
  2. function verifyImage( $type=1,$length=4,$pixel=0,$line=0,$sess_name="verify "){
  3. session_start();
  4. /*長さと幅を定義*/
  5. $width=80;
  6. $height=30;
  7. /*キャンバスを作成*/
  8. $image=imagecreatetruecolor($width, $height);
  9. /*この関数はグラフィックスの色を一致させるために使用され、他の描画関数でも使用できます。パラメータ画像はグラフィックのハンドルを表します。パラメータの赤、緑、青は色の三原色で、値は 0 から 255 までです。ここで黒と白を定義します*/
  10. $white=imagecolorallocate($image, 255, 255, 255 );
  11. $black=imagecolorallocate ($image,0,0,0);
  12. /*この関数は、画像の閉じた長方形の領域に色を付けます。パラメータ x1、y1 および x2、y2 は、それぞれ長方形の対角線の座標です。パラメータcolはペイントされる色を表します */
  13. imagefilledrectangle($image, 1, 1, $width-2, $height-2, $white);
  14. /*検証コードの生成にはbuildRandomString関数が使用されます* /
  15. $ chars=buildRandomString($type,$length);
  16. /*ユーザー入力が正しいかどうかを判断するためにセッションに検証コードを与えます*/
  17. $_SESSION[$sess_name]=$chars;
  18. /*フォント ライブラリを定義します*/
  19. $fontfiles=array('msyh.ttf','msyhbd.ttf','simsun.ttc','SIMYOU.TTF','STUPO.TTF','STKAITI.TTF','STLITI .TTF');
  20. /*ループを使用して検証コードを 1 つずつ画像に書き込みます*/
  21. for($i=0;$i<$length;$i++)
  22. {
  23. $size=mt_rand (14,18);
  24. $angle=mt_rand(-15,15);
  25. /*認証コードの横軸と縦軸*/
  26. $x=5+$i*$size;
  27. $y=mt_rand( 20,26);
  28. $color=imagecolorallocate($image,mt_rand(50,190),mt_rand(50,200),mt_rand(50,90));
  29. $fontfile="../font/".$fontfiles[mt_rand( 0,count($fontfiles) -1)];
  30. $text=substr($chars,$i,1);
  31. /*この関数は、TTF (TrueType フォント) フォントのテキストを画像に書き込みます*/
  32. imagettftext($ image, $size, $ angle, $x, $y, $color, $fontfile, $text);
  33. }
  34. if($pixel)
  35. {
  36. for($i=0;$i<50;$i++)
  37. {
  38. /*this 関数は画像上の点としてプロットできます。パラメータ x と y は描画される点の座標で、パラメータ Col は点の色を表します */
  39. imagesetpixel($image, mt_rand(0,$width-1), mt_rand(0,$height- 1), $black);
  40. }}
  41. if($line)
  42. {
  43. for($i=0;$i<10;$i++)
  44. {
  45. $color=imagecolorallocate($image,mt_rand(50,90) ),mt_rand(50,200), mt_rand(50,90));
  46. /*線分を描画*/
  47. imageline($image, mt_rand(0,$width-1), mt_rand(0,$height-1), mt_rand (0,$width-1) , mt_rand(0,$height-1), $color);
  48. }
  49. }
  50. /*gif形式で出力*/
  51. header("content-type:image/gif");
  52. /*GIF 画像を作成して出力します Web ページに移動します*/
  53. imagegif($image);
  54. /*画像に関連付けられたメモリを解放します*/
  55. imagedestroy($image);
  56. }
コードをコピーします
  1. function buildRandomString($type=1,$length=4){
  2. if($type==1)
  3. {
  4. /*join関数は配列を文字列に変換します。 。 join() 関数は implode() 関数のエイリアスです*/
  5. $chars=join("",range(0,9));
  6. }elseif ($type==2) {
  7. /*array_merge 関数はマージしますarrays*/
  8. $chars=join("",array_merge(range("a","z"),range("A","Z")));
  9. }elseif($type==3)
  10. {
  11. $chars =join("",array_merge(range("a","z"),range("A","Z"),range(0,9)));
  12. }
  13. if($length> ;strlen( $chars))
  14. {
  15. exit("文字列の長さが不十分です");
  16. }
  17. /*文字列をシャッフルします*/
  18. $chars=str_shuffle($chars);
  19. return substr($chars,0, $length) ;
  20. }
  21. ?>
コードをコピー
認証コード


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。