我只想在我的几个控制器中打开 csrf 保护,所以我有
function __construct() {
parent::__construct();
$this->load->library('form_validation');
$this->load->library('tank_auth');
$this->load->helper(array('form', 'url'));
$this->load->model('user_model', '', true);
$this->config->set_item('csrf_protection', TRUE);
}
但这似乎不起作用,尽管当我在页面上执行 var_dump($this->config) 时,它显示 csrf_protection 为 TRUE,但未设置 cookie,并且表单有一个没有值的隐藏字段
<input type="hidden" name="ci_csrf_token" value="" />
Csrf 令牌名称和 cookie 名称均已设置,使用 form_open() 调用表单。
任何帮助将非常感激。
更新:所以这在 2.1.1 版本中是不可能的,因为安全类构造中的行if (config_item('csrf_protection') === TRUE) {
安全类在控制器之前初始化,因此控制器中的配置项更改自然不会影响它。