php实现留言板功能
这个小小的留言板功能适合班级内或者公司内部之间的讨论,对话和留言,非常的方便,更重要的是无需网络,对于公司管理层来说是非常乐于常见的,
下面是这个留言板的写法:
1 首先是登录页面:
<form action="chuli.php" method="post"> <div style="margin-left: 500px; margin-top: 200px; height: 250px; width: 250px">/*为了把登录表放到页面中间,比较美观*/ <h1>公司内部留言板</h1> <div style="margin-top: 20px">用户名:<input type="text" name="username"/></div><br/> <div>密 码:<input type="password" name="password"/></div><br/> <div><input type="submit" value="登录"/></div> </div> </form>
2 登录页面完成后要进入登录处理页面了,也就是上面提交到的chuli.php
<?php session_start(); // 登录之后要把所包含登录的页面连接起来,开启session include("DADB.class.php"); $db=new DADB(); $user=$_POST["username"]; $pwd=$_POST["password"]; $sql="select password from yuangong where username='{$user}'"; $arr=$db->Query($sql); if($arr[0][0]==$pwd && !empty($pwd)) { $_SESSION["username"]=$user; header("location:main.php"); } else { echo"登录失败"; } ?>
如图所示,是登录页面
3.登录完成后是进入主页面,也就是显示自己收到的对话内容,下面是设计的数据库的表格和主页面的代码:
<body> <div><h3><a href="fabu.php" rel="external nofollow" >发布信息</a> <a href="tuichu.php" rel="external nofollow" >退出系统</a></h3> </div> <br/><br/> <h2>留言信息:</h2> <table cellpadding="0" cellspacing="0" border="1" width="60%"> <tr> <td>发送人</td> <td>接收人</td> <td>发送时间</td> <td>信息内容</td> </tr> <?php session_start(); if(empty($_SESSION["username"])) { header("location:login.php"); } $user=$_SESSION["username"]; include("DADB.class.php"); $db=new DADB(); $sql="select * from liuyan where recever='$user' or recever='all' "; $arr=$db->Query($sql); foreach($arr as $v) { $fjr=uname($v[1]); $jsr=uname($v[2]); echo"<tr> <td>{$fjr}</td> //发送人和接收人要用到姓名,所以这里我们调用了一个方法 <td>{$jsr}</td> <td>{$v[3]}</td> <td>{$v[4]}</td> </tr>"; } function uname($user) //运用了uname方法 { global $db; //要想方法里面也可以用$db 这里用了全局变量 if($user=="all") { return "所有人"; }else { $sql1="select name from yuangong where username='{$user}'"; $att=$db->Query($sql1); return $att[0][0];} } ?> </table> </body>
4代码写到这里,比较重要的部分就完成了,下面是要进入发布信息页面了,相当于之前写的添加的页面,其处理页面也是和之前没什么区别的,差别在于现在的处理页面是在用户登录的情况下操作的,需要用session把所有的登录情况下的页面连接起来
<h1>发布信息</h1> <a href="main.php" rel="external nofollow" >主页面</a> <br /> <br /> <?php session_start(); if(empty($_SESSION["username"])) { header("location:login.php"); exit; } $user = $_SESSION["username"]; include("DADB.class.php"); $db = new DADB(); $shaoyou = "select * from firend where me='{$user}'"; $ahaoyou = $db->Query($shaoyou); ?> <form action="fabuchuli.php" method="post"> <div>接收人: <select name="jsr"> <option value="all">所有人</option> <?php foreach($ahaoyou as $v) { $name = uname($v[2]); echo "<option value='{$v[2]}'>{$name}</option>"; } ?> </select> </div> <br /> <div> 信息内容:<textarea name="neirong"></textarea> </div><br /> <input type="submit" value="发送" /> </form> <?php function uname($user) { global $db; if($user=="all") { return "所有人"; } else { $sql1 = "select name from yuangong where username='{$user}'"; $att = $db->Query($sql1); return $att[0][0]; } } ?> </body> //这是发布页面的代码 和添加页面的代码相似 <?php <?php session_start(); $re=$_POST["jsr"]; $comment=$_POST["neirong"]; $time=date("Y-m-d H:i:s"); //获取当前时间 $_SESSION["username"]=$user; include("DADB.class.php"); $db=new DADB(); $sql="insert into liuyan VALUES ('','{$user}','{$jsr}','{$time}','{$comment}',false)"; if($db->Query($sql,0)) { header("location:main.php"); } else{ echo"发布失败"; } ?> ?>
一个简单的留言板已经完成了,退出的时候需要清除session 并且返回到登录页面
//退出页面代码 <?php session_start(); unset($_SESSION["username"]); header("location:login.php"); ?>