SQL 注入式攻击及应对方案

SQL 是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系型数据库系统··

SQL注入式攻击,攻击者把SQL命令插入到Web表单的输入域或页面请求的查询字符串中,达到欺骗服务器执行恶意的SQL命令,在某些表单中,用户输入等待内容直接用来构造动态SQL命令,或作为存储过程的输入参数,这类表单特别容易沙鸥到SQL注入式攻击

总结:程序开发过程中不注意书写规范,对sql语句和关键字未进行过滤,导致客户端可以通过全局变量 get 或 post 提交 sql 语句到服务端正常运行

防止方法:

  1. 过滤掉一些常见的数据库关键字;select, insert, update, delete等,或通过系统函数 addslashes(需要过滤的内容)来进行过滤

  2. 在PHP配置文件中 registet_global=off;(设置为关闭状态),作用是将注册全局变量关闭掉

  3. sql语句书写的时候,尽量不要忽略小引号和单引号

  4. 提高数据库命名技巧,对于一些重要字段根据程序特点命名,取不易猜到的

  5. 对于常用的方法加以封装、避免直接暴露sql语句

  6. 开启安全模式, safe_mode = on

  7. 控制错误信息,关闭错误提示信息,将错误信息写入系统日志文件

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值