Files
liche/market/libraries/MyCaptcha.php
T
2022-09-29 14:30:16 +08:00

141 lines
4.7 KiB
PHP

<?php
/** Captcha 验证码类
* Date: 2011-02-19
* Author: fdipzone
*/
class MyCaptcha
{//class start
private $sname = '';
public function __construct($sname = '')
{ // $sname captcha session name
$this->sname = $sname == '' ? 'm_captcha' : $sname;
}
/** 生成验证码图片
* @param int $length 验证码长度
* @param Array $param 參數
* @return IMG
*/
public function create($length = 4, $param = array())
{
if (!$param['base64']) {
Header("Content-type: image/PNG");
}
$authnum = $this->random($length); //生成验证码字符.
$width = isset($param['width']) ? $param['width'] : 13; //文字宽度
$height = isset($param['height']) ? $param['height'] : 18; //文字高度
$pnum = isset($param['pnum']) ? $param['pnum'] : 100; //干扰象素个数
$lnum = isset($param['lnum']) ? $param['lnum'] : 2; //干扰线条数
if (!$param['base64']) {
$this->captcha_session($this->sname, $authnum); //将随机数写入session
}
$pw = $width * $length + 10;
$ph = $height + 6;
$im = imagecreate($pw, $ph); //imagecreate() 新建图像,大小为 x_size 和 y_size 的空白图像。
$black = ImageColorAllocate($im, 238, 238, 238); //设置背景颜色
$values = array(
mt_rand(0, $pw), mt_rand(0, $ph),
mt_rand(0, $pw), mt_rand(0, $ph),
mt_rand(0, $pw), mt_rand(0, $ph),
mt_rand(0, $pw), mt_rand(0, $ph),
mt_rand(0, $pw), mt_rand(0, $ph),
mt_rand(0, $pw), mt_rand(0, $ph)
);
imagefilledpolygon($im, $values, 6, ImageColorAllocate($im, mt_rand(170, 255), mt_rand(200, 255), mt_rand(210, 255))); //设置干扰多边形底图
/* 文字 */
for ($i = 0; $i < strlen($authnum); $i++) {
$font = ImageColorAllocate($im, mt_rand(0, 50), mt_rand(0, 150), mt_rand(0, 200));//设置文字颜色
$x = $i / $length * $pw + rand(1, 6); //设置随机X坐标
$y = rand(1, $ph / 3); //设置随机Y坐标
imagestring($im, mt_rand(4, 6), $x, $y, substr($authnum, $i, 1), $font);
}
/* 加入干扰象素 */
for ($i = 0; $i < $pnum; $i++) {
$dist = ImageColorAllocate($im, mt_rand(0, 255), mt_rand(0, 255), mt_rand(0, 255)); //设置杂点颜色
imagesetpixel($im, mt_rand(0, $pw), mt_rand(0, $ph), $dist);
}
/* 加入干扰线 */
for ($i = 0; $i < $lnum; $i++) {
$dist = ImageColorAllocate($im, mt_rand(50, 255), mt_rand(150, 255), mt_rand(200, 255)); //设置线颜色
imageline($im, mt_rand(0, $pw), mt_rand(0, $ph), mt_rand(0, $pw), mt_rand(0, $ph), $dist);
}
ImagePNG($im); //以 PNG 格式将图像输出到浏览器或文件
$content = '';
if ($param['base64']) {
$content = ob_get_clean();
}
ImageDestroy($im); //销毁一图像
if ($param['base64']) {
$base64 = base64_encode($content); // base64加密后的图片
return ['base64' => 'data:image/png;base64,' . $base64, 'text' => $authnum];
}
}
/** 检查验证码
* @param String $captcha 验证码
* @param int $flag 验证成功后 0:不清除session 1:清除session
* @return boolean
*/
public function check($captcha, $flag = 1)
{
if (empty($captcha)) {
return false;
} else {
if (strtoupper($captcha) == $this->captcha_session($this->sname)) { //检测验证码
if ($flag == 1) {
$this->captcha_session($this->sname, '');
}
return true;
} else {
return false;
}
}
}
/* 产生随机数函数
* @param int $length 需要随机生成的字符串數
* @return String
*/
private function random($length)
{
$hash = '';
//$chars = 'ABCDEFGHIJKLMNPQRSTUVWXYZ23456789';
$chars = 'abcdefghijklmnpqrstuvwxyz23456789';
$max = strlen($chars) - 1;
for ($i = 0; $i < $length; $i++) {
$hash .= $chars[mt_rand(0, $max)];
}
return $hash;
}
/** 验证码session处理方法
* @param String $name captcha session name
* @param String $value
* @return String
*/
private function captcha_session($name, $value = null)
{
if (isset($value)) {
if ($value !== '') {
$_SESSION[$name] = $value;
} else {
unset($_SESSION[$name]);
}
} else {
return isset($_SESSION[$name]) ? $_SESSION[$name] : '';
}
}
} // class end
?>