Maison > développement back-end > tutoriel php > Comment utiliser PHP pour se connecter à la base de données afin d'implémenter la fonction de forum de messages

Comment utiliser PHP pour se connecter à la base de données afin d'implémenter la fonction de forum de messages

一个新手
Libérer: 2023-03-16 12:46:01
original
1868 Les gens l'ont consulté

PHP implémente la fonction de babillard électronique :

1 Le premier est la page de connexion :

<!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="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" style="margin-top: 20px;">用户名:</span>
                <input type="text" class="form-control" name="uid" placeholder="请输入用户名">
            </p>
            <p class="input-group xiugai" style="margin-top: 10px;">
                <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>
Copier après la connexion

2 Une fois la page de connexion terminée, vous devez accéder à la page de traitement de connexion, qui est le messageloginchuli soumis ci-dessus.php

<?phpsession_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");
}
?>
Copier après la connexion

La page de connexion ressemble à ceci :

Après vous être connecté, vous entrerez dans la page principale, qui affiche la conversation. contenu que vous avez reçu. Voici la base de données conçue. Le code du formulaire et de la page principale :

<!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="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 style="margin-left: 880px; margin-top: 50px;font-size: 20px;" >
            <a href="publish_info.php" >发布信息</a>
            <a href="tuichuchuli.php">退出系统</a>
            </p>
        <table class="table table-bordered mess" style="margin-top: -40px;">
            <caption style="font-size: 20px;">
                留言信息:
            </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>
Copier après la connexion

Quittez le système de connexion pour mettre en œuvre la déconnexion de l'utilisateur, et le code de fonction pour revenir à la page de connexion est le suivant :

<?phpsession_start();
    $uid = $_SESSION["uid"];
    unset($uid);
    header("location:messlogin.php");
?>
Copier après la connexion

Maintenant que le code est écrit ici, la partie la plus importante est terminée. L'étape suivante consiste à saisir les informations de version. page, qui équivaut à la page ajoutée écrite auparavant. La page de traitement est également la même qu'avant. La différence est que maintenant La page de traitement est utilisée lorsque l'utilisateur est connecté. Vous devez utiliser la session pour connecter tous les connectés. pages

L'effet de la page principale est comme indiqué dans la figure :

4. à tout le monde

Le code est le suivant :

<!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="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><?phpsession_start();
    $uid = $_SESSION["uid"];
    if (empty($_SESSION["uid"])) {
    header("location:messlogin.php");
    exit ;
}
?> <p style="margin-left: 500px;
    margin-top: 150px;
    "> <p style="margin-left: 60px;
    margin-bottom: 20px;
    font-size: 20px;
    " > <a href="message.php" >查看信息</a> <a href="seemess.php" style="margin-left: 80px;
    " >查看发送信息</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>
Copier après la connexion

La page de message est telle qu'affichée :

Après avoir publié les informations, vous devez entrer. la page de traitement, qui est l'infochuli.php soumis, et enfin revenir à l'interface d'envoi d'informations

<?phpsession_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 "发送失败!";
}
?>
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal