php 预编译防止注入代码解析

本文介绍了PHP防止SQL注入的一种方法——预编译。通过`bind_param`函数绑定SQL参数并指定数据类型,如`s`表示字符串,`i`表示整型,`d`表示双精度浮点型,`b`表示布尔值。接着,使用`bind_result`绑定结果集,确保与数据返回的位数匹配。最后,通过`prepare`预编译SQL语句,并执行`execute`来执行SQL并使用`fetch`获取结果。
摘要由CSDN通过智能技术生成

案例源码:

<?php
$username = $_GET['username'];
$pass = $_GET['password'];
//建立连接
$link = mysqli_connect("localhost","root","root","test");
//创建sql   ?为占位符
$sql = "select * from users where user_name = ? and password = ?";
//进行预编译
$preSql = $link->prepare($sql);
//ss 表示两个string类型,对占位符进行赋值
$preSql -> bind_param("ss",$username,$pass);
//绑定返回的结果集,result的值要与数据库返回的位数相等
$preSql -> bind_result($id,$user_name,$password,$img);
//执行查询
$preSql -> execute();
//获取结果
$preSql ->fetch();
if ($user_name == $username && $password = $pass){
    echo "<script>alert('登录成功')</script>";
    echo "<script>window.location='index.php'</script>";//进行跳转
}else{
    echo "<script>alert('登录失败,请重新登录')</script>";
    echo "<script>window.locat
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值