>백엔드 개발 >PHP 튜토리얼 >PHP에서 게시판 기능(데이터베이스 연결)을 구현한 예

PHP에서 게시판 기능(데이터베이스 연결)을 구현한 예

黄舟
黄舟원래의
2017-09-12 09:10:413191검색

아래 편집기는 메시지 보드 기능을 구현하기 위해 PHP를 사용하여 데이터베이스에 연결하는 예를 제공합니다(권장). 편집자님이 꽤 좋다고 생각하셔서 지금 공유하고 모두에게 참고용으로 드리도록 하겠습니다. 편집기를 따라 살펴보겠습니다.

PHP는 메시지 게시판 기능을 구현합니다.

1 첫 번째는 로그인 페이지입니다.


<!DOCTYPE html>
<html>
 <head>
  <meta charset="UTF-8">
  <title>留言板登录</title>
  <script src="bootstrap/js/jquery-1.11.2.min.js"></script>
  <script src="bootstrap/js/bootstrap.min.js"></script>
  <link href="bootstrap/css/bootstrap.min.css" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="stylesheet" type="text/css"/>
 </head>
 <style>
  .header{
   margin-left: 550px;
   margin-top: 150px;
   height: 300px;
   max-width: 300px;
  }
  .xiugai{
   max-width: 200px;
  }
  .login{
   margin-top: 10px;
  }
 </style>
 <body>
  <form action="messloginchuli.php" method="post">
  <p class="header">
   <h2>开发部内部留言板</h2>
   <p class="input-group xiugai">
    <span class="input-group-addon" >用户名:</span>
    <input type="text" class="form-control" name="uid" placeholder="请输入用户名">
   </p>
   <p class="input-group xiugai" >
    <span class="input-group-addon">口令:</span>
    <input type="text" class="form-control" name="pwd" placeholder="请输入口令">
   </p>
   <button type="submit" class="btn btn-success login">登录</button>
  </p>
 </form>
 </body>
</html>

2 즉, 위에서 제출한 messageloginchuli.php


<?php
session_start();  // 登录之后要把所包含登录的页面连接起来,开启session
$uid = $_POST["uid"];
$pwd = $_POST["pwd"];
require_once "./DBDA.class.php";
$db = new DBDA();
$sql = "select password from yuangong where username=&#39;{$uid}&#39;";
$arr = $db->query($sql,0);
//var_dump($arr[0][0]);
if($arr[0][0]=$pwd && !empty($pwd)){
 $_SESSION["uid"]=$uid;
 header("location:message.php");
}

?>

로그인 페이지 효과는 그림과 같습니다.

3. 완료되면 받은 대화 내용을 표시하는 메인 페이지로 들어가게 됩니다. 다음은 설계된 데이터베이스 테이블과 메인 페이지의 코드입니다.


<!DOCTYPE html>
<html>
 <head>
  <meta charset="UTF-8">
  <title></title>
  <script src="bootstrap/js/jquery-1.11.2.min.js"></script>
  <script src="bootstrap/js/bootstrap.min.js"></script>
  <link href="bootstrap/css/bootstrap.min.css" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="stylesheet" type="text/css"/>
 </head>
 <style>
  .mess{
   max-width: 800px;
   margin-left: 250px;
   margin-top: 150px;
  }
 </style>
 <body>
  <?php
  session_start();
  $uid = $_SESSION["uid"];
  if(empty($_SESSION["uid"])){
   header("location:messlogin.php");
   exit;
  }
  ?>
  <p >
   <a href="publish_info.php" rel="external nofollow" >发布信息</a>
   <a href="tuichuchuli.php" rel="external nofollow" >退出系统</a>
   </p>
  <table class="table table-bordered mess" >
   <caption >
    留言信息:
   </caption>
   
   <thead>
    <tr>
     <th>发送人</th>
     <th>发送时间</th>
     <th>接收人</th>
     <th>信息内容</th>
    </tr>
   </thead>
   <tbody>
    <?php
    require_once "./DBDA.class.php";
    $db = new DBDA();
    $sql = "select * from liuyan where recever=&#39;{$uid}&#39; or recever=&#39;all&#39;";
    $arr = $db->query($sql,0);
    foreach($arr as $v){
     echo "<tr>
     <td>{$v[1]}</td>
     <td>{$v[2]}</td>
     <td>{$v[3]}</td>
     <td>{$v[4]}</td>
    </tr>";
    }
    ?>
    
   </tbody>
  </table>

 </body>
</html>

사용자 로그아웃을 구현하려면 로그인 시스템을 종료하세요. 그리고 로그인 페이지로 돌아갑니다.


 <?php
session_start();
$uid = $_SESSION["uid"];
unset($uid);
header("location:messlogin.php");

?>

코드는 여기에 작성되어 있습니다. 비교 중요한 부분은 완료되었습니다. 다음은 추가된 페이지와 동일한 릴리스 정보 페이지로 들어가는 것입니다. 처리 페이지도 이전과 동일합니다. 차이점은 현재 처리 페이지는 사용자가 로그인한 상태에서 작동한다는 점입니다. , 모든 로그인 페이지를 연결하려면 세션을 사용해야 합니다.

메인 페이지의 효과

4. 마지막으로 누구에게나 정보를 보낼 수 있는 정보 공개 페이지가 있습니다.

코드는 다음과 같습니다.


<!DOCTYPE html>
<html>
 <head>
  <meta charset="UTF-8">
  <title>发布信息界面</title>
  <script src="bootstrap/js/jquery-1.11.2.min.js"></script>
  <script src="bootstrap/js/bootstrap.min.js"></script>
  <link href="bootstrap/css/bootstrap.min.css" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="stylesheet" type="text/css"/>
 </head>
 <style>
  .mess{
   max-width: 200px;
   margin-top: 10px;
  }
  .mess1{
   margin-top: 10px;
  }
  .opt{
   max-width: 200px;
   margin-left: 80px;
  }
  .txt{
   max-width: 200px;
  }
 </style>
 <body>
<?php
session_start();
$uid = $_SESSION["uid"];
if (empty($_SESSION["uid"])) {
 header("location:messlogin.php");
 exit ;
}
?>
 <p >
  <p >
   <a href="message.php" rel="external nofollow" >查看信息</a>
   <a href="seemess.php" rel="external nofollow" >查看发送信息</a>
   </p>
  <form class="form-horizontal" role="form" action="infochuli.php" method="post">
   
   <p class="form-group">
     <label for="firstname" class="col-sm-2 control-label mess1">接收人:</label>
     <p class="form-group ">
      <select class="form-control opt" name="recever">
       <option value="all">所有人</option>
      <?php
      
      require_once "./DBDA.class.php";
      $db = new DBDA(); 

       //这里可以给特定的朋友发送信息的sql语句
      //$sql = "select firend.firend,yuangong.name from firend,yuangong where firend.firend 
      //= yuangong.username and firend.me = &#39;{$uid}&#39;";
      $sname = "select * from yuangong where username not in (&#39;{$uid}&#39;)";
      $arr = $db->query($sname,0);      
      //var_dump($arr[0][2]);
      foreach($arr as $v){
       echo "<option value=&#39;{$v[0]}&#39;>{$v[2]}</option>";
      }
      ?>      
      </select>
     </p>
    </p>
   
   <p class="form-group">
    <label for="lastname" class="col-sm-2 control-label mess1">信息内容:</label>
    <p class="col-sm-10">
     <textarea class="form-control txt" rows="3" name="content"></textarea>
    </p>
   </p>
   <p class="form-group">
    <p class="col-sm-offset-2 col-sm-10">
     <button type="submit" class="btn btn-default">
     发送
     </button>
    </p>
   </p>
  </form>
 </p>

 </body>
</html>

메시지 페이지는 다음과 같습니다:

5. 정보를 게시한 후 제출된 infochuli.php인 처리 페이지로 들어가야 하며 마지막으로 정보 전송 인터페이스


<?php
session_start();
$uid = $_SESSION["uid"];
$recever = $_POST["recever"];
$content = $_POST["content"];
$arr = $_POST["recever"];
$t = date("Y-m-d H:i:s");
require_once "./DBDA.class.php";
$db = new DBDA();
$sql = "insert into liuyan values(&#39;&#39;,&#39;{$uid}&#39;,&#39;{$t}&#39;,&#39;{$recever}&#39;,&#39;{$content}&#39;,0)";
$arr = $db->query($sql);
if($arr && !empty($arr)){
 header("location:publish_info.php");
}else{
 echo "发送失败!";
}
?>
로 돌아갑니다.

위 내용은 PHP에서 게시판 기능(데이터베이스 연결)을 구현한 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.