CI框架提交表单时出现 Disallowed Key Characters 错误提示


文件位置 system/core/Input.php

这和 CI 的字符串处理类设计有关,是这样的,通过get、post方法提交的字符串,CI 都交给 system/core/Input.php 这个类去处理

url 里有非法字符。其实主要还包括post,get,cookie,session里面的数据,如果有非法字符串就会提示这个错误了。

所以要确保这些里面都没有非法字符串。


将Input类里的

1
2
3
4
5
6
7
8
   function  _clean_input_keys( $str )  
{  
      if  ( ! preg_match( "/^[a-z0-9:_/-]+$/i" $str ))  
      {  
          exit ( 'Disallowed Key Characters.' );  
      }  
      return  $str ;  
  }


换成

1
2
3
4
5
6
7
8
9
function  _clean_input_keys( $str )  
{  
      $config  = &get_config( 'config' );  
     if  ( ! preg_match( "/^[" . $config [ 'permitted_uri_chars' ]. "]+$/i" , rawurlencode( $str )))  
     {  
         exit ( 'Disallowed Key Characters.' );  
     }  
    return  $str ;  
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值