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

本文详细解析了CodeIgniter框架中Input类对于GET、POST等请求数据的非法字符过滤机制。通过对Input.php核心文件的修改示例,展示了如何自定义合法字符集以避免因非法字符导致的应用退出错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


文件位置 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;  
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值