• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    PHP使用PDO、mysqli扩展实现与数据库交互操作详解

    本文实例讲述了PHP使用PDO、mysqli扩展实现与数据库交互操作。分享给大家供大家参考,具体如下:

    数据库

    在我们开发php时,可能有人已经学习了php数据库的连接交互,也可能正准备学习。如今,按照php的发展趋势,mysql扩展已经停止开发,在以后的发展中可能被淘汰,如mysql->query(),mysql->connect()等以后可能就无法使用。所以我们要尽量使用PDO和mysqli扩展。

    PDO

    基本操作如下:

    ?php
    // PDO + MySQL
    $servername = "localhost";
    $username = "username";
    $password = "password";
    try{
      $pdo = new PDO('mysql:host=$servername;dbname=myDB', '$username',
       '$password');
      echo '连接成功';
    }
    catch(PDOExcepton $e){
      echo $e->getMessge();
    }
    $statement = $pdo->query("SELECT some_field FROM some_table");
    $row = $statement->fetch(PDO::FETCH_ASSOC);
    echo htmlentities($row['some_field']);
    // PDO + SQLite
    $pdo = new PDO('sqlite:/path/db/foo.sqlite');
    $statement = $pdo->query("SELECT some_field FROM some_table");
    $row = $statement->fetch(PDO::FETCH_ASSOC);
    echo htmlentities($row['some_field']);
    //关闭连接
    $pdo=null;
    
    

    PDO 并不会对 SQL 请求进行转换或者模拟实现并不存在的功能特性;它只是单纯地使用相同的 API 连接不同种类的数据库。

    更重要的是,PDO 使你能够安全的插入外部输入(例如 ID)到你的 SQL 请求中而不必担心 SQL 注入的问题。这可以通过使用 PDO 语句和限定参数来实现。

    我们来假设一个 PHP 脚本接收一个数字 ID 作为一个请求参数。这个 ID 应该被用来从数据库中取出一条用户记录。下面是一个错误的做法:

    ?php
    $pdo = new PDO('sqlite:/path/db/users.db');
    $pdo->query("SELECT name FROM users WHERE id = " . $_GET['id']); // -- NO!
    
    

    这是一段糟糕的代码。你正在插入一个原始的请求参数到 SQL 请求中。这将让被黑客轻松地利用[SQL 注入]方式进行攻击。想一下如果黑客将一个构造的 id 参数通过像 http://domain.com/?id=1%3BDELETE+FROM+users 这样的 URL 传入。这将会使 $_GET[‘id'] 变量的值被设为 1;DELETE FROM users 然后被执行从而删除所有的 user 记录!因此,你应该使用 PDO 限制参数来过滤 ID 输入。

    ?php
    $pdo = new PDO('sqlite:/path/db/users.db');
    $stmt = $pdo->prepare('SELECT name FROM users WHERE id = :id');
    $id = filter_input(INPUT_GET, 'id', FILTER_SANITIZE_NUMBER_INT); // -- 首先过滤您的数据 ,对于INSERT,UPDATE等特别重要
    $stmt->bindParam(':id', $id, PDO::PARAM_INT); // -- 通过PDO自动对SQL进行清理
    $stmt->execute();
    
    

    这是正确的代码。它在一条 PDO 语句中使用了一个限制参数。这将对外部 ID 输入在发送给数据库之前进行转义来防止潜在的 SQL 注入攻击。

    对于写入操作,例如 INSERT 或者 UPDATE,进行数据过滤并对其他内容进行清理(去除 HTML 标签,Javascript 等等)是尤其重要的。PDO 只会为 SQL 进行清理,并不会为你的应用做任何处理。

    mysqli扩展

    mysqli基本操作如下:

    ?php
    $servername = "localhost";
    $username = "username";
    $password = "password";
    // 创建连接
    $conn = new mysqli($servername, $username, $password);
    // 检测连接
    if ($conn->connect_error) {
      die("连接失败: " . $conn->connect_error);
    } 
    echo "连接成功";
    ?>
    
    

    注意在以上面向对象的实例中 $connect_error 是在 PHP 5.2.9 和 5.3.0 中添加的。如果你需要兼容更早版本 请使用以下代码替换:

    // 检测连接
    if (mysqli_connect_error()) {
      die("数据库连接失败: " . mysqli_connect_error());
    }
    
    

    数据库交互

    ul>
    ?php
    foreach ($db->query('SELECT * FROM table') as $row) {
      echo "li>".$row['field1']." - ".$row['field1']."/li>";
    }
    ?>
    /ul>
    
    

    这从很多方面来看都是错误的做法,主要是由于它不易阅读又难以测试和调试。而且如果你不加以限制的话,它会输出非常多的字段。

    其实还有许多不同的解决方案来完成这项工作 — 取决于你倾向于 面向对象编程(OOP)还是函数式编程 — 但必须有一些分离的元素。

    来看一下最基本的做法:

    ?php
    function getAllFoos($db) {
      return $db->query('SELECT * FROM table');
    }
    foreach (getAllFoos($db) as $row) {
      echo "li>".$row['field1']." - ".$row['field1']."/li>"; 
    }
    
    

    这是一个不错的开头。将这两个元素放入了两个不同的文件于是你得到了一些干净的分离。
    创建一个类来放置上面的函数,你就得到了一个「Model」。创建一个简单的.php文件来存放表示逻辑,你就得到了一个「View」。这已经很接近 MVC — 一个大多数框架常用的面向对象的架构。

    //foo.php

    ?php
    $db = new PDO('mysql:host=localhost;dbname=testdb;charset=utf8', 'username', 'password');
    // 使模板可见
    include 'models/FooModel.php';
    // 实例化类
    $fooModel = new FooModel($db);
    // Get the list of Foos
    $fooList = $fooModel->getAllFoos();
    // 显示视图
    include 'views/foo-list.php';
    
    

    //models/FooModel.php

    ?php
    class FooModel
    {
      protected $db;
      public function __construct(PDO $db)
      {
        $this->db = $db;
      }
      public function getAllFoos() {
        return $this->db->query('SELECT * FROM table');
      }
    }
    
    

    //views/foo-list.php

    ?php foreach ($fooList as $row): ?>
      ?= $row['field1'] ?> - ?= $row['field1'] ?>
    ?php endforeach ?>
    
    

    许多框架都提供了自己的数据库抽象层,其中一些是设计在 PDO 的上层的。这些抽象层通常将你的请求在 PHP 方法中包装起来,通过模拟的方式来使你的数据库拥有一些之前不支持的功能。这种抽象是真正的数据库抽象,而不单单只是 PDO 提供的数据库连接抽象。这类抽象的确会增加一定程度的性能开销,但如果你正在设计的应用程序需要同时使用 MySQL,PostgreSQL 和 SQLite 时,一点点的额外性能开销对于代码整洁度的提高来说还是很值得的。

    更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP基于pdo操作数据库技巧总结》、《php+mysqli数据库程序设计技巧总结》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

    希望本文所述对大家PHP程序设计有所帮助。

    您可能感兴趣的文章:
    • PHP如何初始化PDO及原始SQL语句操作
    • PHP中PDO关闭连接的方法问题
    • PHP使用PDO 连接与连接管理操作实例分析
    • php+pdo实现的购物车类完整示例
    • PHP使用PDO实现mysql防注入功能详解
    • PHP PDO和消息队列的个人理解与应用实例分析
    • php pdo连接数据库操作示例
    • PHP使用PDO创建MySQL数据库、表及插入多条数据操作示例
    • PHP PDO预处理语句及事务的使用
    上一篇:Smarty模板语法详解
    下一篇:PHP抽象类和接口用法实例详解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    PHP使用PDO、mysqli扩展实现与数据库交互操作详解 PHP,使用,PDO,mysqli,扩展,实现,