PHP를 사용하여 CMS 시스템의 현장 메시징 기능을 구현하는 방법
인터넷의 대중화와 함께 다양한 웹사이트도 활성화되어 사용자 간의 커뮤니케이션을 향상시켰습니다. 많은 CMS 시스템에 꼭 필요한 기능 중 하나입니다. 이 기사에서는 PHP를 사용하여 간단한 CMS 시스템의 사이트 내 메시징 기능을 구현하는 방법을 소개하고 해당 코드 예제를 제공합니다.
우선, 사이트 내 메시지와 관련된 데이터를 저장할 데이터베이스를 만들어야 합니다. "users"라는 사용자 테이블을 포함하는 "cms"라는 데이터베이스가 이미 있다고 가정합니다. 내부 메시지와 관련된 정보를 저장하려면 사용자 테이블에 두 개의 필드를 추가해야 합니다. 하나는 보낸 사람의 ID를 나타내는 sender_id이고 다른 하나는 받는 사람의 ID를 나타내는 receive_id입니다.
다음은 현장 메시지 목록을 생성하는 SQL문입니다.
CREATE TABLE IF NOT EXISTS messages ( id INT(11) AUTO_INCREMENT PRIMARY KEY, sender_id INT(11), receiver_id INT(11), subject VARCHAR(255), body TEXT, created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP, FOREIGN KEY (sender_id) REFERENCES users (id), FOREIGN KEY (receiver_id) REFERENCES users (id) );
다음으로 사용자의 현장 메시지 목록을 표시하기 위해 CMS 시스템에 페이지를 추가해야 합니다. 이 페이지에서 사용자는 받은 현장 메시지를 확인하고 특정 메시지를 보도록 선택할 수 있습니다.
먼저, 사용자가 받은 사이트 메시지 목록을 얻기 위해 데이터베이스를 쿼리해야 합니다. 다음은 사이트 내 메시지 목록을 가져오는 데 사용되는 간단한 함수입니다.
function getInboxMessages($userId) { $query = "SELECT * FROM messages WHERE receiver_id = '$userId' ORDER BY created_at DESC"; $result = mysqli_query($conn, $query); $messages = mysqli_fetch_all($result, MYSQLI_ASSOC); return $messages; }
그런 다음 페이지의 사이트 내 메시지 목록을 반복하고 각 사이트 내 메시지의 제목과 보낸 사람 정보를 표시합니다. 사용자가 클릭하여 특정 사이트 메시지를 볼 수 있는 링크를 제공합니다.
$inboxMessages = getInboxMessages($userId); foreach($inboxMessages as $message) { $senderId = $message['sender_id']; $subject = $message['subject']; // 查询发件人的信息 $query = "SELECT * FROM users WHERE id = '$senderId'"; $result = mysqli_query($conn, $query); $sender = mysqli_fetch_assoc($result); echo "<div>"; echo "<p>发件人:" . $sender['username'] . "</p>"; echo "<p>标题:" . $subject . "</p>"; echo "<a href='view_message.php?id=" . $message['id'] . "'>查看</a>"; echo "</div>"; }
위 코드에서는 사용자 테이블을 쿼리하여 보낸 사람의 정보를 얻고 관련 정보를 페이지에 표시합니다. 동시에 특정 현장 메시지 내용을 표시하는 링크를 볼 수 있는 view_message.php
페이지를 제공합니다. view_message.php
页面,用于展示具体的站内信内容。
接下来,我们需要创建view_message.php
view_message.php
페이지를 생성해야 합니다. $messageId = $_GET['id']; // 查询站内信的具体内容 $query = "SELECT * FROM messages WHERE id = '$messageId'"; $result = mysqli_query($conn, $query); $message = mysqli_fetch_assoc($result); echo "<p>发件人:" . $message['sender_id'] . "</p>"; echo "<p>标题:" . $message['subject'] . "</p>"; echo "<p>内容:" . $message['body'] . "</p>"; echo "<p>时间:" . $message['created_at'] . "</p>";
위 내용은 PHP를 사용하여 CMS 시스템의 사이트 내 메시징 기능을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!