更新时间:2022-12-08 来源:黑马程序员 浏览量:
SQL注入产生的根本原因是因为程序在开发过程中不注意规范书写SQL语句和对特殊字符进行过滤,导致客户端可以通过全局变量POST和GET提交一些特殊字符,让SQL语句正常执行。
防止SQL注入的常用方法有如下几种:
1.开启配置文件中的magic_quotes_gpc和magic_quotes_runtime设置,对一些字符过滤。
2.执行SQL语句时使用addslashes()函数,对特殊字符转义后再执行SQL语句。
3.SQL语句书写尽量不要省略小引号(")和单引号('')。
4.过滤掉SQL语句中的一些关键字,例如update、insert、delete、select、*等。
5.提高数据库表和字段的命名技巧,对一些重要的字段根据程序的特点命名,取不易被猜到的名字。
6.PHP配置文件中设置register_globals为off,关闭全局变量注册。
7.控制错误信息,不要在浏览器上输出错误信息,将错误信息写到日志文件中。
8.使用mysqli或PDO预处理。