2

使用以下在线指南(以及底部的 1.7x 修复)http://codeigniter.com/forums/viewthread/94299/

Recaptcha 验证在本地工作时效果很好(在我的 Windows 机器和朋友的 OSX 机器上测试)但是当我的服务器和他的 web 主机上载时,recaptch 的验证例程似乎没有得到检查,即使页面上的其他验证确实如此. 但是没有抛出任何错误,我查看了代码并且无法找出问题所在。如果有人可以帮助我找出发生了什么,将不胜感激。

这是处理这个问题的类

应用程序/库/MY_Form_Validation.php

<?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');
class MY_Form_Validation extends CI_Form_Validation
{

    function MY_Form_Validation()
    {
        parent::CI_Form_Validation();
    }

    function recaptcha_matches() {
        $CI = & get_instance();
        $CI->config->load('recaptcha');
        $public_key = $CI->config->item('recaptcha_public_key');
        $private_key = $CI->config->item('recaptcha_private_key');
        $response_field = $CI->input->post('recaptcha_response_field');
        $challenge_field = $CI->input->post('recaptcha_challenge_field');
        $response = recaptcha_check_answer($private_key, $_SERVER['REMOTE_ADDR'], $challenge_field, $response_field);

        if ($response->is_valid) {
            return TRUE;
        }
        else {
            $this->recaptcha_error = $response->error;
            $this->set_message('recaptcha_matches', 'The %s is incorrect. Please try again.');
            return FALSE;
        }
    }

应用程序/帮助者/recaptcha_helper.php

http://pastebin.com/m352494c3

application/controllers/forum.php - 发布线程方法

public function add_thread($category_id = null)
{
    $category = $this->forums->get_category($category_id);
    if ($category == false)
    {
        $this->template->set('title', 'Invalid Page');
        $data['error_message'] = "Invalid category to add thread too";
        $this->template->load('template', 'error', $data);
        return;
    }

    $user = $this->users->get($this->session->userdata('user_id'));

    $data['category_id'] = $category['id'];
    $data['category_title'] = $category['category_title'];
    $data['loggedin'] = $this->session->userdata('loggedin');

    $this->form_validation->set_rules('thread_title', 'Title', 'required');
    $this->form_validation->set_rules('thread_body', 'Body', 'required');

    if (!$data['loggedin'])
    {
        $this->form_validation->set_rules('recaptcha_challenge_field', 'answer to the security question', 'recaptcha_matches');
    }

    if ($this->form_validation->run() == FALSE)
    {
        $this->template->load('template', 'forums/add_thread', $data);
        return;
    }

    $thread['thread_title'] = $this->input->post('thread_title');
    $thread['thread_body'] = $this->input->post('thread_body');
    if($user==false){
        $thread['user_id'] = -1;
    }else{
        $thread['user_id'] = $user->id;
    }
    $thread['posted_date'] = date("Y-m-d H:i:s");
    $thread['category_id'] = $category_id;

    $this->forums->add_thread($thread);
    redirect('forums/view/' . $category_id, 'refresh');
}
4

1 回答 1

0

在我的代码中,我通常这样写:

$response = recaptcha_check_answer($private_key, $CI->input->ip_address(), $challenge_field, $response_field);

$CI->input->ip_address()有更复杂的方法来检测客户端 IP 地址。比REMOTE_ADDR单独使用。

另外,请确保您的私钥和公钥都与服务器的域名匹配,或者使用全局密钥。

于 2010-02-02T05:27:35.497 回答