2015-03-13 12:45:57 +08:00
|
|
|
<?php
|
2015-04-25 19:50:07 +08:00
|
|
|
require_once 'cool-php-captcha-0.3.1/captcha.php';
|
2015-03-13 12:45:57 +08:00
|
|
|
function generate_captcha($extra = '1234567890') {
|
2015-04-25 19:50:07 +08:00
|
|
|
global $config;
|
2015-03-13 12:45:57 +08:00
|
|
|
|
2015-04-25 19:50:07 +08:00
|
|
|
$text = rand_string($config['captcha']['length'], $extra);
|
2015-03-13 12:45:57 +08:00
|
|
|
|
|
|
|
$captcha = new SimpleCaptcha();
|
|
|
|
|
|
|
|
$cookie = rand_string(20, "abcdefghijklmnopqrstuvwxyz");
|
|
|
|
|
|
|
|
ob_start();
|
|
|
|
$captcha->CreateImage($text);
|
|
|
|
$image = ob_get_contents();
|
|
|
|
ob_end_clean();
|
|
|
|
$html = '<image src="data:image/png;base64,'.base64_encode($image).'">';
|
|
|
|
|
2015-04-25 19:50:07 +08:00
|
|
|
$query = prepare("INSERT INTO `captchas` (`cookie`, `extra`, `text`, `created_at`) VALUES (?, ?, ?, ?)");
|
2015-03-13 12:45:57 +08:00
|
|
|
$query->execute( [$cookie, $extra, $text, time()]);
|
|
|
|
|
|
|
|
return array("cookie" => $cookie, "html" => $html);
|
|
|
|
}
|
|
|
|
|
|
|
|
function rand_string($length, $charset) {
|
|
|
|
$ret = "";
|
|
|
|
while ($length--) {
|
|
|
|
$ret .= mb_substr($charset, rand(0, mb_strlen($charset, 'utf-8')-1), 1, 'utf-8');
|
|
|
|
}
|
|
|
|
return $ret;
|
|
|
|
}
|
|
|
|
|
2015-04-25 19:50:07 +08:00
|
|
|
function cleanup () {
|
|
|
|
global $config;
|
|
|
|
prepare("DELETE FROM `captchas` WHERE `created_at` < ?")->execute([time() - $config['captcha']['expires_in']]);
|
2015-03-13 12:45:57 +08:00
|
|
|
}
|
|
|
|
|