php+Memcached实现简单留言板功能示例

5年以前  |  阅读数:853 次  |  编程语言:PHP 

本文实例讲述了php+Memcached实现简单留言板功能。分享给大家供大家参考,具体如下:

MyPdo.php


    <?php
    class MyPdo{
      private $pdo;
      function __construct()
      {
        $this->pdo = $this->getPdo();
      }
       /**
       * CreatePDO
       *
       * @return PDO
       */
      public function getPdo()
      {
        $dbms='mysql';
        $dbName='testdb';
        $user='root';
        $pwd='diligentyang';
        $host='localhost';
        $dsn="$dbms:host=$host;dbname=$dbName";
        try{
          $pdo=new PDO($dsn,$user,$pwd);
        }catch(Exception $e){
          echo $e->getMessage().'<br>';
          exit();
        }
        $pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
        $pdo->exec("set names utf8");
        return $pdo;
      }
       /**
       * Execute SQL
       *
       * @param string $sql Sql
       * @param string $mode Mode
       *
       * @return mixed
       */
      function query($sql = "", $mode = "array")
      {
        $sql = trim($sql);
        if ($sql == "") {
          $this->showErrors("the mothe query neet at least one param!");
        }
        $query = $this->pdo->query($sql);
        if (!$query) {
          $this->showErrors("the sql string is false");
        }
        if (strpos(strtolower($sql), "select") ===false) {
          return $query;
        }
        switch ($mode) {
        case 'array' :
          $res = $query->fetchAll(PDO::FETCH_ASSOC);
          break;
        case 'object' :
          $res = $query->fetchObject();
          break;
        case 'count':
          $res = $query->rowCount();
          break;
        default:
          $this->showErrors("SQLERROR: please check your second param!");
        }
        return $res;
      }
      /**
      * 提示错误
      *
      * @param string $str 错误提示内容
      */
      public function showErrors($str)
      {
        echo "<h1>$str<h1/>";
        exit();
      }
    }

ShowMessage.php


    <?php
    include("MyPdo.php");
    //连接Memcached服务器
    $m = new Memcached();
    $m->addServer('127.0.0.1',11211);
    //获取Memcached中的list
    $res = $m->get("list");
    //如果没有数据,则从数据库中查出,并放入Memcached中,如果有数据则直接输出
    if(!$res){
      $MyPdo = new MyPdo();
      $res = $MyPdo->query("select * from message","array");
      $m->set('list',$res,3600);
    }
    foreach($res as $val){
      echo $val['title']."-------".$val['content']."<br>";
    }
    ?>
    <a href="AddMessage.php" rel="external nofollow" >添加留言</a>

AddMessage.php


    <form action="CheckAdd.php" method="post">
      标题:<input type="text" name="title"><br>
      内容:<input type="text" name="content"><br>
      <input type="submit" value="提交">
    </form>

CheckAdd.php


    <?php
    include("MyPdo.php");
    //连接Memcached服务器
    $m = new Memcached();
    $m->addServer('127.0.0.1',11211);
    $title = $_POST['title'];
    $content = $_POST['content'];
    $MyPdo = new MyPdo();
    $res = $MyPdo->query("insert into message(title,content) values('$title','$content')");
    if($res){//如果insert语句执行成功则清除Memcache中的缓存
      $m->delete("list");
    }
    header("location:ShowMessage.php");

运行结果如下所示:

注:此例子只是简单实现了,留言列表和添加留言功能,需要注意的是,如果对数据库的数据有了添加或修改,需要清除缓存,然后重新缓存一下,已保证数据显示同步。

更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP+MySQL留言板开发专题》、《php缓存技术总结》、《PHP数组(Array)操作技巧大全》、《php字符串(string)用法总结》、《PHP错误与异常处理方法总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

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

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
文件下载
贪吃蛇
双位运算符
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
发送邮件
年的日历图
提取后缀名
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例