mysql5.2防注入_防止SQL 注入;如何进行防SQL 注入。

本文介绍了防止SQL注入的多种方法,包括开启magic_quotes_gpc和magic_quotes_runtime设置,使用addslashes转换SQL语句,避免关键字过滤,正确书写SQL语句,设置register_globals为off,控制错误信息不公开,采用预处理语句如mysqli或PDO,并提倡使用安全的数据库命名策略。
摘要由CSDN通过智能技术生成

防止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、控制错误信息,不要再浏览器上输出错误信息,将错

误信息写到日志文件中。

如何进行防SQL 注入?

1、过滤掉一些常见的数据库操作关键字:

select,insert,update,delete,and,*等

或者通过系统函数:addslashes(需要被过滤的内容)来

进行过滤。

2、在PHP 配置文件中

Register_globals=off;设置为关闭状态//作用将注册

全局变量关闭。

比如:接收POST 表单的值使用$_POST['user'],如果将

register_globals=on;直接使用$user 可以接收表单的

值。

3、SQL 语句书写的时候尽量不要省略小引号(tab 键

上面那个)和单引号

4、提高数据库命名技巧,对于一些重要的字段根据

程序的特点命名,取不易被猜到的

5、对于常用的方法加以封装,避免直接暴漏SQL 语

6、开启PHP 安全模式

Safe_mode=on;

7、打开magic_quotes_gpc 来防止SQL 注入

Magic_quotes_gpc=off;默认是关闭的,它打开后将

自动把用户提交的sql 语句的查询进行转换,把'转为

\',这对防止sql 注入有重大作用。

因此开启:magic_quotes_gpc=on;

8、控制错误信息

关闭错误提示信息,将错误信息写到系统日志。

9、使用mysqli 或pdo 预处理。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值