【问题标题】:How do I validate a form field in Codeigniter when using Get parameters?使用 Get 参数时如何验证 Codeigniter 中的表单字段?
【发布时间】:2012-05-18 11:51:07
【问题描述】:

在我将表单切换为 method="get" 之前,我的表单运行良好。现在我无法让 form_validation->run() 评估为 TRUE。

这是我打开表单的方式:

echo form_open( '', array( 'method' => 'get' ) );

这是唯一需要验证的部分:

$this->form_validation->set_rules( 'states', 'states', 'required' );

这是我检查表单是否经过验证的方式:

if( $this->form_validation->run() == FALSE )

我还需要做什么才能使用 Get 参数吗?我在配置中打开了参数($config['allow_get_array'] = TRUE;)。如果我跳过验证,表单可以正常工作,所以我知道 CI 系统可以正常读取 url。

【问题讨论】:

    标签: forms validation codeigniter post get


    【解决方案1】:

    对于 CodeIgniter 3,您可以将 GET 数组传递给 set_data 函数。例如:
    $this->form_validation->set_data($this->input->get());

    【讨论】:

    【解决方案2】:

    只需添加:

    $_POST['states'] = $this->input->get('states');
    

    用于表单验证之前的验证状态字段

    $this->form_validation->set_rules('states', 'states', 'required|trim');
    

    【讨论】:

      【解决方案3】:

      Codeigniter 论坛上的这篇帖子建议使用 form validation does not work with Get Parameters,这正是 Codeigniter 的方式。

      【讨论】:

      • 只需介入并对 GET 请求进行自己的验证。根据输出的数据,可以使用 htmlspecialchars(GET, ENT_QUOTES, 'encoding') 在最低级别处理 XSS。表单验证只是一个帮手。事先制定您的应用程序结构,看看 CI 可以提供哪些与帮助程序/库相关的内容,然后塑造您自己的工作流程。
      • FYI ... 如果在 POST 参数上运行表单验证的页面的 URI 中有 GET 参数,Codeigniter 表单验证将失败。
      【解决方案4】:

      Codeigniter 在其中一些帖子之后发生了变化。我认为gX的回答是正确的。

      用户手册中的说明,特别是 Validating an Array (other than $POST) 部分,对我来说非常有用(截至今天),而且非常简单。

      在您的 $this->form_validation->set_rules 行之前,您指定要验证的数组:

      $data = array(
          'username' => 'johndoe',
          'password' => 'mypassword',
          'passconf' => 'mypassword');
      
      $this->form_validation->set_data($data);
      

      【讨论】:

        【解决方案5】:

        正如您在 Form_validation.php 文件中看到的那样,他们在类中的任何地方都硬编码了 $_POST ;-(

        如果你也想支持 $_GET,这很容易(而且很脏哦),你可以创建一个新属性:

        public function __construct($rules = array())
        {
            $this->inputData = array_merge($_POST, $_GET);
            ...
        }
        

        由于没有静态方法,因此在此类中的任何地方都将 $_POST 替换为 $this->inputData。

        我知道不建议编辑供应商文件,但真的,你需要它,去做吧 ;-)

        【讨论】:

          【解决方案6】:

          试图做类似的事情,但归结为你的代码结构。

          1. 使用通常的邮寄方式提交表单。这将允许您执行所有后期验证。
          2. 然后使用 redirect() 使用“/”将所有数据发送到控制器内部或外部的不同方法。
          3. 最后,接收所有参数的方法将处理数据库事务并将其呈现给视图。

          希望对你有帮助。

          【讨论】:

            【解决方案7】:

            验证数组($_POST 除外)

            有时您可能想要验证不是源自 $_POST 数据的数组。

            在这种情况下,您可以指定要验证的数组:

            $data = array(
                    'username' => 'johndoe',
                    'password' => 'mypassword',
                    'passconf' => 'mypassword'
            );
            
            $this->form_validation->set_data($data);
            

            注意。在定义任何验证规则之前,您必须调用 set_data() 方法。

            无论您是在验证 $_POST 数据还是您选择的其他数组,创建验证规则、运行验证和检索错误消息的工作方式都是一样的。

            【讨论】:

              【解决方案8】:

              将文件 Form_validation.php 复制到 Form_get_validation.php 并在所有 POST 单词中重命名为单词 GET 并将类命名为 CI_Form_get_validation。验证时,调用 form_get_validation

              【讨论】:

                猜你喜欢
                • 2016-07-22
                • 2011-01-29
                • 1970-01-01
                • 1970-01-01
                • 1970-01-01
                • 2012-11-14
                • 1970-01-01
                • 1970-01-01
                • 1970-01-01
                相关资源
                最近更新 更多