mysql预编译防止注入_预处理(防止sql注入的一种方式)

本文介绍了如何通过MySQL预编译防止SQL注入,强调了预处理的原理和优点,包括减少分析时间、节省带宽以及增强安全性。通过展示面向对象的PHP代码示例,详细展示了预处理过程,包括连接数据库、设置字符集、创建SQL模板、预处理阶段、绑定参数、执行插入操作以及关闭预处理和数据库连接。
摘要由CSDN通过智能技术生成

/*

防止 sql 注入的两种方式:

1. 人为提高代码的逻辑性,使其变得更严谨,滴水不漏。 比如说 增加判断条件,增加输入过滤等,但是智者千虑必有一失。(不推荐)

2. sql 语句的预处理

*/

// 预处理: 就是在程序正式编译之前,事先处理,因为有些功能实现是一样的,只是发生了一些简单的值替换

/*

********** 预处理的原理: *********

insert into register_info values(?,?,?,?);

01. 创建 sql语句模板,并发送到数据库。预留的值使用参数 ? 标记

02. 数据库对模板解析,编译,对sql 语句模板执行查询优化,并存储结果不输出

03. 最多将绑定的参数传给之前 ? 标记的地方,模板执行语句。如果传的参数不一样,模板就可以多次使用。但是对模板的解析只需要做一次

********** 预处理的优点 ***********

01. 预处理语句大大减少了分析时间,只做了一次增删改查(至于值被多次赋予,已经不需要数据库来操作)

02. 绑定参数减少了服务器带宽,你只需要发送查询或者增加的参数,而不是整个 sql 语句

03. 预处理语句能很好的防止 sql注入,因为参数的发送不会影响一开始对模板的解析,编译,模版又是自己定义的,根本不会有漏洞

*/

// 面向对象

// 1. 连接数据库服务器,选择数据库 register

$mysqli

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值