参考视频:https://www.bilibili.com/video/BV1Js411i74j?p=8

环境:phpstudy 2018        PHP 5.X     PHPmyadmin

目录结构 :

运行效果:

代码: 第一个文件,文件名为 item.php

<?php
class Message{
    var $name;
    var $time;
    var $contet;
    
    function __construct($n,$t,$c){
        $this->name = $n;
        $this->time = $t;
        $this->content = $c;
    }
    function show(){
        echo "Name :".$this->name."<br>";
        echo "Time :".$this->time."<br>";
        echo "Content :".$this->content."<br>";
        echo "=================================================="."<br>";
    }
}
//$m = new Message ("zhang","2020-3-6","xxxxxxxx");
//$m->show();
class DB{
    var $database = null ;
    function __construct (){
        $dbhost = "localhost";
        $account = "root";
        $password = "root";
        
        $this->database = mysql_connect($dbhost,$account,$password); //连接phpmyadmin
        if($this->database){
            echo "connection ";
        }else{
            echo "fail ";
        }
        $result = mysql_select_db("db_message2",$this->database); //连接成功之后,继续选择连接phpmyadmin中的具体哪个数据库
        if($result){
            echo "choose ";
        }else{
            echo "fail choose !!";
        }
    }
}
$a = new DB();
?>

第二个文件 文件名为 MessageBoard.php    代码如下

<?php
include_once ('item.php');
class MessageBoard extends DB{ //extends 是继承父类的数据库
    var $messages = array();

    function __construct(){
      parent::__construct(); //写这个的原因是,因为这里已经有了一个__construct了,还需要在导入上面那个__construct,所以说得声明一下
      $this->receivemessage();
      $this->loaddata();
      $this->showallmessage();
      $this->showform();
   }
    function receivemessage(){
    echo "1";    
    if(count($_POST) != 0){
        //$this->savedata($_POST['username'],data("Y-m-d h:i:s",time()),$_POST['content']);
        $this->savedata($_POST['username'],$_POST['time'],$_POST['content']);
    }
   }
    function savedata($u,$t,$c){
        /*echo "username :".$u."<br>";
        echo "time :".$t."<br>";
        echo "content :".$c."<br>";*/
        echo '<br>'.$_POST['username'];
        $sql = "INSERT INTO `db_message2`.`all_messages2` (`id`, `name`, `time`, `content`) VALUES (NULL, '".$u."', '".$t."', '".$c."');";
        mysql_query($sql);
        echo 'fffffffffffff';
    echo "2";
    }
    function loaddata(){
     echo "3";
     //$temp = new Message("zhang","2013-9-6","hahhahahaha");
     $sql = "SELECT * FROM `all_messages2` LIMIT 0, 30 ";
     $result = mysql_query($sql);
     while ($row = mysql_fetch_array($result)){ //这些都是最后在完善的,先写大的框架,也就是先写函数,最后在完善函数
         $temp = new Message( $row['name'], $row['time'],$row['content']);
         array_push($this->messages , $temp);
     }
    }
    function showallmessage(){
    echo "4";
    foreach($this->messages as $m ){ //这些都是最后在完善的,先写大的框架,也就是先写函数,最后在完善函数
        $m->show();
    }
}
    function showform(){
    echo "5";
    echo "<form action='' method='POST'>";
    echo "Name: "."<input type='text' name='username'>"."<br>";
    echo "time: "."<input type='text' name='time'>"; //这些都是最后在完善的,先写大的框架,也就是先写函数,最后在完善函数
    echo "Content: "."<input type='text' name='content'>";
    echo "<input type='submit'>";
    echo "</form>";
}
}
$mb = new MessageBoard();
?>

数据库结构

总结和记录常犯的几个错误:

1.可能C和PY的代码写习惯了,变量名前面老是忘记加$符号。

2.不要看PHP留言板这个项目很小,越小的项目,越能看出一个人的功底。这个项目虽然说很小,但是在写项目之前也要把思路捋清楚,最好是画个E-R图,不要怕浪费时间,一个项目真正浪费时间的并不是写代码的时候,而是写代码的思考,把E-R图写出来,照着E-R图写,不就清楚多了,养成好习惯,做大项目会受益的。

3.写代码的时候不要一个功能一个功能的写,先把整体的框架写出来,在慢慢完善每个功能!!!!

4.不得不说,PHP写后台确实容易些,归根结底就是发展时间久,函数啥的都很全面。

PHP留言板制作(MySQL+PHP)的更多相关文章

  1. javascript-DOM操作-留言板制作

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  2. html的留言板制作(js)

    这次留言板运用到了最基础的localstorage的本地存储,展现的效果主要有: 1.编写留言2.留言前可以编辑自己的留言昵称.不足之处: 1.未能做出我喜欢的类似于网易的叠楼功能. 2.未能显示评论 ...

  3. php写留言板

    简单的PHP留言板制作 做基础的留言板功能  需要三张表: 员工表,留言表,好友表 首先造一个登入页面: <form action="drcl.php" method=&qu ...

  4. 利用Asp.net和Sql Server实现留言板功能

    本教程设及到:使用SQL Server查询分析器创建数据库:SQL查询语句常用的一些属性值:触发器创建和使用:存储过程的创建,ASP使用存储过程. 正文: 一.创建数据库: 创建一个feedback数 ...

  5. Web开发从零单排之二:在自制电子请帖中添加留言板功能,SAE+PHP+MySql

    在上一篇博客中介绍怎样在SAE平台搭建一个html5的电子请帖网站,收到很多反馈,也有很多人送上婚礼的祝福,十分感谢! web开发从零学起,记录自己学习过程,各种前端大神们可以绕道不要围观啦 大婚将至 ...

  6. php+mysql 最简单的留言板

    学完了记得动手操作. 測试地址(未过滤) <html> <body> <head><meta http-equiv="Content-Type&qu ...

  7. 2019-10-12,html+php+mysql简单留言板,作业

    php+mysql简易留言板,实现注册,登录,注销,查看留言,删除留言 1,index.html登录页面 代码: <!doctype html> <html> <head ...

  8. Django入门3 简单留言板项目案例及mysql驱动的安装配置

    新建jangostart项目 使用manager.py新建app即单独的应用 创建一个message应用 manage.py@djangostart > startapp message 如果a ...

  9. vue+egg.js+mysql一个前后端分离留言板项目

    一.前序 我相信每个人前端搬运工和我想法都是一样的,都有一个做全栈的梦,无奈面对众多的后台语言,却不从下手,今天由我来带你们潜入全栈的门槛,注意是门槛.能不能学的会后面的内容全靠坚持了. 我今天主要做 ...

随机推荐

  1. Mac如何像Windows一样在文件系统中查看文件?

    许多Windows系统用户刚转向Mac的时候,肯定非常不适应Mac系统独特的文件系统,就像安卓转iOS系统一样,那么Mac电脑如何像Windows系统一样,能够查看电脑上的各个盘,如C盘D盘等等,然后 ...

  2. 如何输入x的平方

    随着电脑的普及,现在都流行在电脑上做教学课件,撰写文章,尤其是理科文献,涉及的数学符号有很多,它包括了我们常见的四则运算符号和平方.立方等,也包括了高等数学中用到的积分.极限符号等,打这些公式就需要用 ...

  3. 有什么数据恢复软件可以恢复CF数据

    虽然现在SD卡出现并且日益流行,但是CF卡(Compact Flash)作为一种存储设备,仍然是专业数码相机的主流标准.不仅是数码相机,CF接口还广泛用于PDA.笔记本电脑和包括台式机在内的各种设备. ...

  4. Kafka分布式查询引擎

    1.概述 Kafka是一个分布式消息中间件系统,里面存储着实际场景中的数据.Kafka原生是不支持点查询的,如果我们想对存储在Topic中的数据进行查询,可能需要对Topic中的数据进行消费落地,然后 ...

  5. java面试复习重点:类的管理及常用工具,教你抓住面试的重点!

    java复习: 类的管理及常用工具类 包 写在程序文件的第一行 一个Java 源文件中只能声明一个包, 且声明语句只能作为源文件的第一条指令 导入类能导入非public类,但是不能用因为在其他包缺省的 ...

  6. Python爬虫合集:花6k学习爬虫,终于知道爬虫能干嘛了

    爬虫Ⅰ:爬虫的基础知识 爬虫的基础知识使用实例.应用技巧.基本知识点总结和需要注意事项 爬虫初始: 爬虫: + Request + Scrapy 数据分析+机器学习 + numpy,pandas,ma ...

  7. 20200311_最新爬取mzitu

    废话不多, 直接上代码, python3.6: import requests from bs4 import BeautifulSoup import os import time; import ...

  8. OpenCV阈值处理函数threshold处理32位彩色图像的案例

    ☞ ░ 前往老猿Python博文目录 ░ 一.概述 openCV图像的阈值处理又称为二值化,之所以称为二值化,是它可以将一幅图转换为感兴趣的部分(前景)和不感兴趣的部分(背景).转换时,通常将某个值( ...

  9. moviepy执行TextClip.search方法时报错TypeError: a bytes-like object is required, not str

    ☞ ░ 前往老猿Python博文目录 ░ 执行TextClip.search方法时,报错: >>> from moviepy.editor import * >>> ...

  10. PyQt(Python+Qt)学习随笔:树型部件QTreeWidget的itemAbove、itemBelow方法作用探究

    老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 在QTreeWidget的方法中,对于itemBelow.itemAbove方法,官网文档介绍非常简 ...