我想在我的几个控制器中打开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()调用。
任何帮助都将非常感激。
Update:所以从2.1.1版本开始这是不可能的,因为安全类构造if (config_item('csrf_protection') === TRUE) {
安全类是在控制器之前初始化的,所以控制器中配置项的改变自然不会影响到它。
我有一个解决办法。创建一个自定义应用程序/core/MY_Security.php,并将以下内容放入其中:
<?php if ( !defined( 'BASEPATH' ) ) exit( 'No direct script access allowed' );
class MY_Security extends CI_Security
{
public function csrf_verify( )
{
foreach ( config_item('csrf_excludes') as $exclude )
{
$uri = load_class('URI', 'core');
if ( preg_match( $exclude, $uri->uri_string() ) > 0 )
{
// still do input filtering to prevent parameter piggybacking in the form
if (isset($_COOKIE[$this->_csrf_cookie_name]) && preg_match( '#^[0-9a-f]{32}$#iS', $_COOKIE[$this->_csrf_cookie_name] ) == 0)
{
unset( $_COOKIE[$this->_csrf_cookie_name] );
}
return;
}
}
parent::csrf_verify( );
}
}
这将检查以下排除项,您需要将其放入应用程序/config.php的CSRF部分:
$config['csrf_excludes'] = array
( '@^/?excluded_url_1/?@i'
, '@^/?excluded_url_2/?@i' );
每个匹配的URL模式将被排除在CSRF检查之外。你可以在http://rubular.com
构建正则表达式欢呼