PHP怎么实现留言板功能

PHPz
PHPz 原创
2020-06-24 11:41:25 3404浏览

PHP实现留言板功能

作为一个PHP的初学者,我试着写了一个留言板,页面有点丑,多多见谅,嘻嘻嘻
我们写留言板需要用到数据库,所以我们先要建立三个表
user表

friend表

text表

首先需要写一个注册与登录

注册
zhuce.html

<meta charset="utf-8">
<title>zhuce</title>
</head>
<body>
<form method="POST" action="zhuce.php">
<p style="margin-left: 500px;margin-top:200px;height: 250px;width: 250px">
<h1>用户注册页面</h1>
用户名:<input type="text" name="username">
<p>密&nbsp;&nbsp;&nbsp;码:<input type="password" name="password">
<p><input type="submit"  name="submit" value="注册"></p>
</p>
</form>
</body>

zhuce.php

<?php
session_start();
header("Content-type: text/html; charset=utf-8"); //处理数据库用户名乱码
$user=$_POST["username"];
$pwd=$_POST["password"];
if($user==""||$pwd=="")
	 {
      	echo "<script>alert('请确认信息完整性!'); history.go(-1);</script>";  
	 }
else 
   	{
	 		
 			$link=mysqli_connect("localhost","root","","liuyan");//连接数据库
	 		mysqli_query($link,"set names utf8"); 
	 		$sql="select username from user where username='$_POST[username]'";
        	$result=mysqli_query($link,$sql);//执行sql语句
         	$num=mysqli_num_rows($result);//统计执行结果影响的行数
         	if($num)//如果存在该用户
         		{
          			echo "<script>alert('用户名已存在!'); history.go(-1);</script>";  
        		}
            else//注册新用户
        		 { 
         			$sql_insert="insert into user (username,password)values('$_POST[username]','$_POST[password]')";
         			$res_insert=mysqli_query($link,$sql_insert);
         			if($res_insert)
         			{
         				echo "<script>alert('注册成功!');window.location='denglu.html';</script>";  
         			}
         			else
         			{
         				echo "<script>alert('系统繁忙请重试!'); history.go(-1);</script>";  
         			}
          	    }
    }
 ?>

效果如下
在这里插入图片描述

登录
denglu.html

<head>
<meta charset="utf-8">
<title>denglu</title>
</head>
<body>
<form method="POST" action="denglu.php">
<p style="margin-left: 500px;margin-top:200px;height: 250px;width: 250px">
<h1>用户登录页面</h1>
用户名:<input type="text" name="username">
<p>密&nbsp;&nbsp;&nbsp;码:<input type="password" name="password"></p><br/>
<input type="submit"  name="submit" value="登录"> 
<a href="zhuce.html">注册</a>  
 </p>
</form>
</body>

denglu.php

<?php
    session_start();
    	$user=$_POST["username"];
	$_SESSION["uesrname"]=$user;//session超全局变量
	$pwd=$_POST["password"];//获取密码
	if($user=""||$pwd="")
	{
      echo "<script>alert('请输入用户名或密码!'); history.go(-1);</script>";  
	}
	else
	{
		$link=mysqli_connect("localhost","root","","liuyan");//连接数据库
        mysqli_query($link,"set names utf8"); 
        $sql = "select username,password from user where username = '$_POST[username]' and password = '$_POST[password]'";  
		$result=mysqli_query($link,$sql);//执行sql语句
		$num=mysqli_num_rows($result);//统计影响结果行数,作为判断条件
		if($num)
		{
			echo "<script>alert('登录成功!');window.location='003.php';</script>";//登录成功页面跳转  
		}
		else
		{
			echo "<script>alert('用户名或密码不正确!');history.go(-1);</script>";  
	    }
	}
?>

效果如下
在这里插入图片描述
下面需要我们写一个登录进去的页面,它显示别人给你发来的留言以及进入你要给别人留言的页面或者退出系统,在这里我将html代码嵌入php
php代码如下
003.php

<?php
session_start();
global  $user;//定义$user
global $user1;
$_SESSION["username"]=$user;
$username=$_SESSION["uesrname"];
$user1=implode("",$_SESSION);//将session中的数组变为字符串元素
$link=mysqli_connect("localhost","root","","liuyan");//连接数据库
mysqli_query($link,"set names utf8"); 
$sql="select * from text where recever='{$username}'";
$result=mysqli_query($link,$sql);//执行语句
if($num=mysqli_num_rows($result))//将HTML嵌入PHP中,实现从数据库中获得留言信息
{?>
	<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
</head>
  <body>
 <p>
 	<a href="fabu.html">发布信息</a>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
 	<a href="tuichu.php">退出系统</a></h3></p>
 	<br/><br/>
 	
 	<h2>留言信息:</h2>
 	<table cellpadding="0" cellspacing="0" border="1" width="60%">
<tr bgcolor="#8BBCC7">

	<td>发送人</td>
	<td>接收人</td>
	<td>发送时间</td>
	<td>信息内容</td>
	<?php echo '<pre>';
	while($row=mysqli_fetch_array($result,MYSQLI_ASSOC))
	{?>
		<tr bgcolor="#FFFFFF">
	<td ><?php echo $row['sender'];?>&nbsp;</td>
	<td >&nbsp;<?php echo $row['recever'];?>&nbsp;</td>
	<td >&nbsp;<?php echo $row['comment'];?>&nbsp;</td>
	<td >&nbsp;<?php echo $row['time'];?>&nbsp;</td>
    <?php 
       }
       ?>
</tr>
</table>
</body>
</html>
     <?php	


}?>

效果如下
在这里插入图片描述
#接下来我们就该写发布的页面以及PHP代码了
fabu.html

<head>
	<meta charset="utf-8">
	<title>fabu</title>
</head>
<body>
 <form  method="POST" action="fabu.php">
<h1>发布信息<h1>
<a href="003.php">主页面</a>
<p>接收人:<input type="text" name="recever">
</select>
</p>
</select>
</p>
<br/>
<p>
	信息内容:<textarea input type="text" name="neirong"></textarea>
</p><br/>
<input type="submit" value="发送">
</form>

fabu.php

<?php
session_start();
header("Content-type: text/html; charset=utf-8");
global $user;
$re=$_POST["recever"];//获取recever
$comment=$_POST["neirong"];//获取留言
@date_default_timezone_set(PRC);//将数组变为字符串函数
$time=date("Y-m-d G:i:s");//获取时间,G为24小时制
$_SESSION["username"]=$user;//开启session
$user1=implode("",$_SESSION);//将数组转为字符串
$link=mysqli_connect("localhost","root","","liuyan");//连接数据库
mysqli_query($link,"set names utf8"); 
$sql="insert into text(sender,recever,comment,time) values('$user1','$re','$comment','$time')";
$result=mysqli_query($link,$sql);//执行语句
$sql1="insert into friend(me,friend) values('$user1','$re')";//将me,friend存入数据库
$result=mysqli_query($link,$sql1);//执行语句
if($recever=""||$comment="")
{
	echo "<script>alert('发布失败!');window.location='fabu.html';</script>";
}
else
{
	echo "<script>alert('发布成功!');window.location='fabu.html';</script>";
}
?>

效果如下
在这里插入图片描述
最后是退出系统

<?php
session_start();
unset($_SESSION["uesrname"]);
echo "<script>alert('退出成功!');window.location='denglu.html';</script>"; 
?>

效果如下
在这里插入图片描述
第一次写博客,写得不好多有见谅,希望对大家学习PHP有所帮助,如有疑问或者改进方法请留言。

更多相关技术文章,请访问PHP中文网

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。