1. recaptchalib.php の 2 つのメソッドを変更します
function _recaptcha_http_post($host, $path, $data, $port = 80) {
$req = _recaptcha_qsencode ($ データ);
$url = $host.$path;
$ch = Curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt( $ch, CURLOPT_RETURNTRANSFER, 1);
// データを送信しています。
curl_setopt($ch, CURLOPT_POST, 1);
//ポスト変数を追加します
curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);
curl_close($ch);エコー $output;
$response = $output;
return $response;
関数 recaptcha_check_answer ($privkey, $remoteip, $response, $extra_params = array())
if ($privkey == null || $privkey == '') {
die ("reCAPTCHA を使用するには、
");
}
if ($remoteip == null || $remoteip == '') {
die ("セキュリティ上の理由から、リモート IP を reCAPTCHA に渡す必要があります");
}
//スパム送信を破棄する
if ($challenge == null || strlen($challenge) == 0 || $response == null || strlen($ response) == 0) {
$recaptcha_response = new ReCaptchaResponse();
$recaptcha_response->error = 'incorrect-captcha-sol'
$res;ポンセ= _recaptcha_http_post (RECAPTCHA_VERIFY_SERVER, "/recaptcha/api/verify",
array (
'privatekey' => $privkey,
'remoteip' => $remoteip,
'challenge' => $challenge,
'response ' => $response
) + $extra_params
);
$answers =explose ("n", $response [1]);
$pos = strpos(); true');
if ($pos === false) {
$recaptcha_response->is_valid = false;
$recaptcha_response->is_valid = true;
}
return $recaptcha_response
}
2.demo.php
コードは次のとおりです。
& lt;フォームアクション= "" method="post">
require_once('recaptchalib.php')
// https://www.google.com/recaptcha/admin/create からキーを取得します
$publickey = "あなたの公開鍵 --- http://www.google.com/recaptcha にアクセスして申請してください";
$privatekey = "あなたの秘密鍵 --- http://www.google.com/ にアクセスしてくださいrecaptcha を適用してください";
# reCAPTCHA からの応答