PHP留言板制作(MySQL+PHP)
参考视频: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)的更多相关文章
- javascript-DOM操作-留言板制作
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- html的留言板制作(js)
这次留言板运用到了最基础的localstorage的本地存储,展现的效果主要有: 1.编写留言2.留言前可以编辑自己的留言昵称.不足之处: 1.未能做出我喜欢的类似于网易的叠楼功能. 2.未能显示评论 ...
- php写留言板
简单的PHP留言板制作 做基础的留言板功能 需要三张表: 员工表,留言表,好友表 首先造一个登入页面: <form action="drcl.php" method=&qu ...
- 利用Asp.net和Sql Server实现留言板功能
本教程设及到:使用SQL Server查询分析器创建数据库:SQL查询语句常用的一些属性值:触发器创建和使用:存储过程的创建,ASP使用存储过程. 正文: 一.创建数据库: 创建一个feedback数 ...
- Web开发从零单排之二:在自制电子请帖中添加留言板功能,SAE+PHP+MySql
在上一篇博客中介绍怎样在SAE平台搭建一个html5的电子请帖网站,收到很多反馈,也有很多人送上婚礼的祝福,十分感谢! web开发从零学起,记录自己学习过程,各种前端大神们可以绕道不要围观啦 大婚将至 ...
- php+mysql 最简单的留言板
学完了记得动手操作. 測试地址(未过滤) <html> <body> <head><meta http-equiv="Content-Type&qu ...
- 2019-10-12,html+php+mysql简单留言板,作业
php+mysql简易留言板,实现注册,登录,注销,查看留言,删除留言 1,index.html登录页面 代码: <!doctype html> <html> <head ...
- Django入门3 简单留言板项目案例及mysql驱动的安装配置
新建jangostart项目 使用manager.py新建app即单独的应用 创建一个message应用 manage.py@djangostart > startapp message 如果a ...
- vue+egg.js+mysql一个前后端分离留言板项目
一.前序 我相信每个人前端搬运工和我想法都是一样的,都有一个做全栈的梦,无奈面对众多的后台语言,却不从下手,今天由我来带你们潜入全栈的门槛,注意是门槛.能不能学的会后面的内容全靠坚持了. 我今天主要做 ...
随机推荐
- gitlab 搭建(基于现有nginx)
普通搭建请看:gitlab 搭建 一.gitlab搭建 1.添加GitLab镜像源并安装gitlab服务器 wget https://mirrors.tuna.tsinghua.edu.cn/gitl ...
- 【知识点】C/C++编码规范
为了提高我们写的代码的可读性,本文章说一下C/C++的编码规范. 一.源文件头部的注释 /******************************************************* ...
- 11_SurfaceView绘图
学习SurfaceView绘图API的使用方法,为接下来使用SurfaceView开发游戏做准备. 1 package com.example.surfaceview; 2 3 import andr ...
- rest-framework:权限组件
一 权限简介 只用超级用户才能访问指定的数据,普通用户不能访问,所以就要有权限组件对其限制 二 局部使用 from rest_framework.permissions import BasePerm ...
- MySQL对数据 对表 对数据操作
------------恢复内容开始------------ MySQL 数据库的操作 创建 create database 数据库名; 指定字符集 create database 数据库名 char ...
- scentos7安装redis,以及redis的主从配置
redis的安装 下载redis安装包 wget http://download.redis.io/releases/redis-4.0.6.tar.gz 解压压缩包 tar -zxvf redis- ...
- 第6章 Python中的动态可执行方法目录
第6.1节 Python代码编译 第6.2节 Python特色的动态可执行方法简介 第6.3节 Python动态执行之动态编译的compile函数 第6.4节 Python动态表达式计算:eval函数 ...
- 由Java 15废弃偏向锁,谈谈Java Synchronized 的锁机制
Java 15 废弃偏向锁 JDK 15已经在2020年9月15日发布,详情见 JDK 15 官方计划.其中有一项更新是废弃偏向锁,官方的详细说明在:JEP 374: Disable and Depr ...
- PLSQL Developer 工具应用
用户scott使用: 解锁scott: 第一步:登陆管理员 SQL语句:Sqlplus sys/tiger as sysdba 第二步:解锁scott SQL语句:Alter user scott a ...
- SpringBoot之自定义拦截器
一.自定义拦截器实现步骤 1.创建拦截器类并实现HandlerInterceptor接口 2.创建SpringMVC自定义配置类,实现WebMvcConfigurer接口中addInterceptor ...