要实现留言功能,发送者和接受者必不可少,其次就是留言时间留言内容。

要实现的功能:

1、登录者只能查看自己和所有人的信息,并能够给好友留言

2、留言板页面,好友采取下拉列表,当留言信息为空时,显示提示,并停留在当前页面

3、查看过的信息,消息显示已读

4、用$_SESSION[]获取登陆者,并用$_SESSION[]防止用户绕过登录直接进入主页面

第一步建数据库:

需要用到的三张表分别为:friend表,yuangong表,chenai表

yuangong表:

friend表:

chenai表

第二步写登录页面:

1、denglu.php

效果图:(简单)

代码:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style>
.aa{
height: 200px;
width: 300px;
margin: 100px auto;
border: 1px solid black;
text-align: center;
line-height: 20px;
padding-top: 50px;
}
</style>
</head>
<body>
<div class="aa">
<form method="post" action="chuli.php">
<div>用户名:<input type="text" name="username"/></div></br>
<div> &nbsp;&nbsp;密码:<input type="text" name="pwd"/></div></br>
<input type="submit" value="登录" />
</form>
</div>
</body>
</html>

2、登录页面的处理页面chuli.php

<?php
session_start(); //开始会话控制
$users = $_POST["username"];
$pwd = $_POST["pwd"];
require "DB.class.php";
$db = new DB();
$sql = "select password from yuangong where UserName = '{$users}'";
//echo $sql;
$arr = $db->query($sql);
//判断用户名和密码是否和数据库匹配
if(count($arr)){
if($arr[0][0]==$pwd && !empty($pwd)){
$_SESSION["username"]="$users"; //存取数据,便于后面的php页面调用
header("location:main.php");
}
}
?>

第三步主页面main.php

效果图:

注:如上图所示:“陈一“为登陆者,故此处为陈一,显示的都是陈一接收到的信息。

代码如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title> </head>
<body>
<?php
//防止用户绕过登录
session_start();
if(empty($_SESSION["username"]))
{
header("location:denglu.php");
exit;
} require "DB.class.php";
$db = new DB();
$zr = $_SESSION["username"];
//显示登录者,并据此只显示接收者是登陆者的留言和群发的留言
$sql2 = "select name from yuangong where username ='{$zr}'";
$arr2 = $db->query($sql2);
$zr = $arr2[0][0]; //取出员工表中username ='{$zr}'的name
echo $zr.",请查看您的留言信息:";
?> <table border="1px" cellpadding="0px" cellspacing="0px" width="50%">
<tr> <td>发送人</td>
<td>接收人</td>
<td>发送时间</td>
<td>信息内容</td>
<td>是否已读</td>
</tr>
<?php //遍历输出属于登陆者的留言和群发消息
$sql ="select * from chenai where Receiver = '{$zr}' or receiver = 'all'";
$arr = $db->query($sql);
foreach($arr as $v){
//当为群发时,显示所有人,不显示all. 如果前面为汉字“所有人”,则不需要此步骤
if($v[2]=="all"){$v[2]="所有人";} // 实现状态的转变
//var_dump($v[5]);
$str = "";
if($v[5])
{
$str = "<span >已读</span>";
}
else{
$str = " <a href='zt-chuli.php?ids={$v[0]}'> 未读</a>";
} echo"<tr>
<td>{$v[1]}</td>
<td>{$v[2]}</td>
<td>{$v[3]}</td>
<td value='{$v[4]}'> <a href='xx-chuli.php?ids={$v[0]}'> {$v[4]} </a></td>
<td>{$str}</td>
</tr>";
}
?>
</table>
<a href="fabu.php">返回留言页面</a> <a href="exit.php">退出系统</a>
</body>
</html>

第四步写留言页面:

1、发布页面fabu.php

效果图:

实现功能:

下拉列表是陈一的好友

留言板内容不能为空!

代码如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style>
.aa{
height: 100px;
width: 300px;
margin: 0px auto;
}
.bb{
height: 200px;
width: 300px;
margin: 0px auto;
}
</style>
</head>
<body>
<div class="aa">
<h2>&nbsp;&nbsp;留言板</h2>
<?php
session_start();
if(empty($_SESSION["username"]))
{
header("location:denglu.php");
exit;
}
require "DB.class.php";
$db = new DB();
$username= $_SESSION["username"];
//获取发送者
$sql3 = "select name from yuangong where username='{$username}'";
$arr3 = $db->query($sql3);
$lyz= $arr3[0][0]; echo "欢 迎 ".$lyz.", 请 留 言!";
?>
</div> <div class="bb">
<form method="post" action="nr-chuli.php" id="bb">
<div>接收人:
<!-- 有问题,从用工表里读出的人并不一定都是我的好友,所以应该从friend表里读取属于我的好友,这样读出来的好友不包含我-->
<!--用下拉列表输出所有好友-->
<select name="receive">
<?php
$sql4 = "select Friend from friend where me='{$lyz}'";
echo $sql4;
$arr4 = $db->query($sql4);
var_dump($arr4); foreach($arr4 as $v){
echo"<option value='{$v[0]}'>{$v[0]}</option>";
}
?> <!--也可以直接把all换成所有人,后面就可以不用转换-->
<option value="all" value="all">All</option>
</select>
</div>
<div>留言:<br /><textarea name="nr" cols="30" rows="10" id="cc"></textarea></div>
<input type="submit" value="发送" onclick="panduan()" /></br>
<a href="denglu.php" >返回登录页面</a>
<a href="main.php">查看我的留言</a>
</form> </div>
</body>
</html>
<!--当留言为空时-->
<script>
function panduan(){
var a = document.getElementById("cc").value;
if(a=="")
{
//给提示
alert ("留言不能为空,您难道对您的好友这么无语么?哈哈请重新输入!");
//页面不跳转
document.getElementById("bb").removeAttribute("action");
}
}
</script>

2、发布处理页面:nr-chuli.php

<?php
session_start();
$_SESSION["username"];
if(empty($_SESSION["username"]))
{
header("location:denglu.php");
exit;
} $receive = $_POST["receive"];
$comment = $_POST["nr"];
$t=date("Y-m-d H:i:s"); $sender = $_SESSION["username"]; //var_dump($sender); require "DB.class.php";
$db = new DB(); //获取发送者
$sql = "select name from yuangong where username='{$sender}'";
$arr = $db->query($sql);
$sender = $arr[0][0];
//var_dump($arr); //往chenai表里添加信息
$sql2 = "insert into chenai values ('','$sender','$receive','$t','$comment',0)";
if($db->query($sql2,0))
{
echo "留言成功!";
}
echo " <a href='fabu.php'>继续留言</a> ";
echo " <a href='main.php'>查看我的留言</a> ";
?>

第五步:信息处理页面xx-chuli.php

实现功能:点击最后一条留言内容,跳转到上面第二图,返回我的留言查看会发现最后一条信息变成已读

代码如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style> .aa{
height: 200px;
width: 300px;
margin-left: 100px;
border: 1px solid black;
}
</style>
</head>
<body> <?php
session_start();
$ids = $_GET["ids"];
$zrname=$_SESSION["username"];
//防止用户绕过登录 if(empty($_SESSION["username"]))
{
header("location:denglu.php");
exit;
} //var_dump($ids);
//var_dump($_SESSION["username"]); require "DB.class.php";
$db =new DB();
//调取登陆者的姓名
$sql = "select name from yuangong where username = '{$zrname}'";
$arr = $db->query($sql);
$zrname=$arr[0][0];
//var_dump($zrname); //获取发送者的姓名
$sql2 = "select sender from chenai where ids='{$ids}'";
$arr2 = $db->query($sql2);
$name=$arr2[0][0];
//var_dump($name); echo $zrname.", 这是".$name."给您的留言:"."</br> </br>"; $sql3 = "select comment from chenai where ids='{$ids}'";
$arr3 = $db->query($sql3);
$nr=$arr3[0][0]; echo "<div class='aa'> {$nr} </div>"; //改变是否已读的状态
$sql4 = "update chenai set states=1 where ids='{$ids}'";
$db->query($sql4,0);
//echo "<a href='zt-chuli.php?ids={$ids}'>我的留言</a>";
// 这样也可以传值
//echo "<a href='fabu.php'>去留言</a>";
?>
<a href="main.php">我的留言</a> <a href="fabu.php">去留言</a>
</body>
</html>

如果不想查看内容,可直接点击未读也可以转成已读:zt-chuli.php

<?php
$ids = $_GET["ids"]; require "DB.class.php";
$db =new DB();
$sql = "update chenai set states=1 where ids='{$ids}'"; var_dump($db->query($sql,0));
if($db->query($sql,0)){
header("location:main.php");
} ?>

 第六步退出登录exit.php

<?php
session_start();
unset($_SESSION["username"]);
header("location:denglu.php");
?>

到这一步,一个简单的留言功能就可以实现了~~~~

用php(session)实现留言板功能----2017-05-09的更多相关文章

  1. php实现留言板功能

    这个小小的留言板功能适合班级内或者公司内部之间的讨论,对话和留言,非常的方便,更重要的是无需网络,对于公司管理层来说是非常乐于常见的, 下面是这个留言板的写法: 1 首先是登录页面: <form ...

  2. 使用PHP连接数据库实现留言板功能

    PHP实现留言板功能: 1 首先是登录页面: <!DOCTYPE html><html>    <head>        <meta charset=&qu ...

  3. jsp中运用application实现共享留言板功能

    jsp中application的知识点总结: 1.一个Web应用程序启动后,将会自动创建一个application对象,在整个应用程序的运行过程中只有这一个application对象,即所有访问该网站 ...

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

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

  5. 利用反馈字段给帝国cms添加留言板功能(图文教程)

    帝国cms的插件中提供信息反馈字段,很多人却不会用.这里谢寒教大家如何来给自己的帝国cms网站添加留言板功能 1.找到添加地址 2.添加字段 3.你可以在字段中添加多种字段类型(有文本域,单行文本框, ...

  6. JS原生编写实现留言板功能

    实现这个留言板功能比较简单,所以先上效果图: 实现用户留言内容,留言具体时间. <script> window.onload = function(){ var oMessageBox = ...

  7. 原生JS实现简单留言板功能

    原生JS实现简单留言板功能,实现技术:css flex,原生JS. 因为主要是为了练手js,所以其中布局上的一些细节并未做处理. <!DOCTYPE html> <html lang ...

  8. python完成留言板功能

    <!DOCTYPE html> <html lang="zh"> <head> <meta charset="utf-8&quo ...

  9. Vue之简易的留言板功能

    今天我将带大家通过Vue的todolist案例来完成一个简易的网页留言板! LES'T GO! 首先我们需要在页面上搭建一个input文本输入框,并设置提交按钮,通过循环指令来完成输入框的信息提交! ...

随机推荐

  1. 【CNMP系列】VIM编辑器详解

    缘起 大学的时候做过Linux内核驱动程序研发,之前写C语言就是用的Vim编辑器,当年的Vim还不如今天之强大,当时的插件也没有现在这么多,只是觉得这个编辑器能满足我想要的所有,查看Linux内核代码 ...

  2. ng2响应式表单-翻译与概括官网REACTIVE FORMS页面

    本文将半翻译半总结的讲讲ng2官网的另一个未翻译高级教程页面. 原文地址. 文章目的是使用ng2提供的响应式表单技术快速搭出功能完善丰富的界面表单组件. 响应式表单是一项响应式风格的ng2技术,本文将 ...

  3. 【小试插件开发】给Visual Studio装上自己定制的功能来提高代码调试效率

    背后的故事 随着项目需求的逐步增加,后端开发框架在我手上也慢慢重构为组件开发模式,整体结构类似于NopCommence.在这种结构中,每个组件所在的类库项目其实是生成到网站项目里指定的一个目录的,然后 ...

  4. Spring 框架原理

    [spring框架原理] Spring框架原理 [博主]高瑞林 [博客地址]http://www.cnblogs.com/grl214 写给读者的话 ------亲爱的读者感谢您对小编的支持,当我正值 ...

  5. CognitiveJ一个Java的人脸图像识别开源分析库

    CognitiveJ 是一个开源的,支持 Java 8 API 的库,用于管理和编排 Java 应用和微软的Cognitive(Project Oxford)机器学习和图像处理库的项目,可以让你查询以 ...

  6. Spring+SpringMVC+MyBatis+easyUI整合优化篇(四)单元测试实例

    日常啰嗦 前一篇文章<Spring+SpringMVC+MyBatis+easyUI整合优化篇(三)代码测试>讲了不为和不能两个状态,针对不为,只能自己调整心态了,而对于不能,本文会结合一 ...

  7. 使用EPPlus读写xlsx文件

    朋友有个需求,想对N张excel表做过滤和合并的处理,拜托我写个小程序.因为用户的背景是非专业用户,因此最好的选择是写个GUI程序,再加上读写excel的需求,所以我的首选就是C#的WinForm了. ...

  8. 老李分享:使用 Python 的 Socket 模块开发 UDP 扫描工具

    老李分享:使用 Python 的 Socket 模块开发 UDP 扫描工具 poptest是业内唯一的测试开发工程师培训机构,测试开发工程师主要是为测试服务开发测试工具,在工作中要求你做网络级别的安全 ...

  9. 如何通过 HSB 颜色模式构建夜间模式

    中国睡眠研究会发布的<2017 年中国青年睡眠现状报告>显示,大约 90% 的人在睡前离不开电子产品. 不知道大家有没有感觉到普通的亮色界面会让我们在夜间使用的时侯感到刺眼,长时间使用会感 ...

  10. 如何高效实现扫描局域网IP、主机名、MAC和端口

    近几年工作经常使用RFID识读器,智能家居网关,温湿度传感器.串口服务器.视频编码器等,一般是有串口和网口,由于现场原因一般较少使用串口,大多使用网口.连接方法是IP地址和端口,有的设备带搜索软件,有 ...