php框架

 首页 > php框架 > 谈CI框架的安全性

谈CI框架的安全性

分享到:
【字体:
导读:
          用过ci框架的人都知道,ci框架能大大缩短你的代码。其实,ci框架更能提高你网站的安全性。 防止对数据库的攻击 数据输入可能引发许多问题。因为 HTML 和数据库的限制,数据中总包...

用过ci框架的人都知道,ci框架能大大缩短你的代码。其实,ci框架更能提高你网站的安全性。


防止对数据库的攻击


  数据输入可能引发许多问题。因为 HTML 和数据库的限制,数据中总包含特定的符号—举例来说,省略符号和引号—可能导致你的数据库遭到攻击,最终得到你无法预料的结果。

解决方案是在把这些数据存入数据库前对这些数据进行相关处理。这样做会浪费一些系统时间,增加一些额外编码。

CI 的表单辅助函数会自动地完成这些工作。因此,当你编写一个输入框时:



PHP 代码

[php] view plaincopy
 
  1. "http://www.php.net/echo" style="color:rgb(66,120,136); text-decoration:none">"color:rgb(0,0,102)">echo form_input"color:rgb(102,204,102)">("color:rgb(255,0,0)">'username'"color:rgb(255,0,0)">'johndoe'"color:rgb(102,204,102)">);  

CI 也隐式地执行下列校验函数:


PHP 代码

[php] view plaincopy
 
  1. "color:rgb(0,0,0)">function form_prep"color:rgb(102,204,102)">("color:rgb(0,0,255)">$str = "color:rgb(255,0,0)">''"color:rgb(102,204,102)">)  
  2. "color:rgb(102,204,102)">{  
  3.     "color:rgb(177,177,0)">if "color:rgb(102,204,102)">("color:rgb(0,0,255)">$str === "color:rgb(255,0,0)">''"color:rgb(102,204,102)">)  
  4.     "color:rgb(102,204,102)">{  
  5.         "color:rgb(177,177,0)">return "color:rgb(255,0,0)">'';  
  6.     "color:rgb(102,204,102)">}  
  7.    
  8.     "color:rgb(0,0,255)">$temp = "color:rgb(255,0,0)">'__TEMP_AMPERSANDS__';  
  9.    
  10.     "color:rgb(128,128,128)">// Replace entities to temporary markers so that  
  11.     "color:rgb(128,128,128)">// htmlspecialchars won't mess them up  
  12.     "color:rgb(0,0,255)">$str = "http://www.php.net/preg_replace" style="color:rgb(66,120,136); text-decoration:none">"color:rgb(0,0,102)">preg_replace"color:rgb(102,204,102)">("color:rgb(255,0,0)">"/&#(color:rgb(0,0,153)">d+);/""color:rgb(255,0,0)">"$tempcolor:rgb(0,0,153)">\1;""color:rgb(0,0,255)">$str"color:rgb(102,204,102)">);  
  13.     "color:rgb(0,0,255)">$str = "http://www.php.net/preg_replace" style="color:rgb(66,120,136); text-decoration:none">"color:rgb(0,0,102)">preg_replace"color:rgb(102,204,102)">("color:rgb(255,0,0)">"/&(color:rgb(0,0,153)">w+);/""color:rgb(255,0,0)">"$tempcolor:rgb(0,0,153)">\1;""color:rgb(0,0,255)">$str"color:rgb(102,204,102)">);  
  14.    
  15.     "color:rgb(0,0,255)">$str = "http://www.php.net/htmlspecialchars" style="color:rgb(66,120,136); text-decoration:none">"color:rgb(0,0,102)">htmlspecialchars"color:rgb(102,204,102)">("color:rgb(0,0,255)">$str"color:rgb(102,204,102)">);  
  16.    
  17.     "color:rgb(128,128,128)">// In case htmlspecialchars misses these.  
  18.     "color:rgb(0,0,255)">$str = "http://www.php.net/str_replace" style="color:rgb(66,120,136); text-decoration:none">"color:rgb(0,0,102)">str_replace"color:rgb(102,204,102)">("http://www.php.net/array" style="color:rgb(66,120,136); text-decoration:none">"color:rgb(0,0,102)">array"color:rgb(102,204,102)">("color:rgb(255,0,0)">"'""color:rgb(255,0,0)">'"'color:rgb(102,204,102)">)http://www.php.net/array" style="color:rgb(66,120,136); text-decoration:none">color:rgb(0,0,102)">arraycolor:rgb(102,204,102)">(color:rgb(255,0,0)">"'"color:rgb(255,0,0)">"""color:rgb(102,204,102)">)color:rgb(0,0,255)">$strcolor:rgb(102,204,102)">);  
  19.    
  20.     "color:rgb(128,128,128)">// Decode the temp markers back to entities  
  21.     "color:rgb(0,0,255)">$str = "http://www.php.net/preg_replace" style="color:rgb(66,120,136); text-decoration:none">"color:rgb(0,0,102)">preg_replace"color:rgb(102,204,102)">("color:rgb(255,0,0)">"/$temp(color:rgb(0,0,153)">d+);/","color:rgb(255,0,0)">"&#color:rgb(0,0,153)">\1;","color:rgb(0,0,255)">$str"color:rgb(102,204,102)">);  
  22.     "color:rgb(0,0,255)">$str = "http://www.php.net/preg_replace" style="color:rgb(66,120,136); text-decoration:none">"color:rgb(0,0,102)">preg_replace"color:rgb(102,204,102)">("color:rgb(255,0,0)">"/$temp(color:rgb(0,0,153)">w+);/","color:rgb(255,0,0)">"&color:rgb(0,0,153)">\1;","color:rgb(0,0,255)">$str"color:rgb(102,204,102)">);  
  23.    
  24.     "color:rgb(177,177,0)">return "color:rgb(0,0,255)">$str;  
  25. "color:rgb(102,204,102)">}  

上述函数捕获像“&”这样的特殊字符,以便在你的页面提交时不会造成混乱。你应该知道,有些字符会引起问题。

并不是所有的用户都会中规中矩的输入符合要求的信息,你也不可能知道使用浏览器输入信息的是什么人,他们在想什么,做什么。你可以使用 CI 来防止输入不符合要求的信息。当然,你大可不必知道 CI 是如何在幕后为你做到这一切的,你只需要简单地输入如下代码:



[php] view plaincopy
 
  1. "http://www.php.net/echo" style="color:rgb(66,120,136); text-decoration:none">"color:rgb(0,0,102)">echo form_input"color:rgb(102,204,102)">("color:rgb(255,0,0)">'username'"color:rgb(255,0,0)">'johndoe'"color:rgb(102,204,102)">);  

分享到:
codeigniter框架开发技巧
(1)自动加载models——php5风格使用这个技巧以后,我们将能够直接创建这个model对象。这个代码是简洁的并且容易理解对象。    使用这个技巧以后会有2个影响。首先你不再需要继承model类了。这个技巧我们需要做的就是添加一个php5风格的 autolader 函数添加这些代码到system/application/config/config.php:如果你也有...
codeigniter框架视频教程_用户权限管理系...
        经过一个多月的不懈努力,终于将用户权限管理系统搞定,后续会抽出时间录制完用户权限管理系统的整套视频教程,此用户权限管理系统借鉴了本人所在互联网公司商业网上购物平台后台权限管理系统思想,分别使用CI框架(codeigniter)、Yii框架、zend framework框架、thinkphp框架和cakephp框架进行了完美的重写,代码量...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……