Home Backend Development PHP Tutorial php mysql chat room tutorial tutorial_PHP tutorial

php mysql chat room tutorial tutorial_PHP tutorial

Jul 13, 2016 pm 04:55 PM
mysql php refresh principle Can Example accomplish build Tutorial program Simple chatroom

Chat rooms can be implemented by many programs, and the principle is simple and can be implemented without refreshing. The simplest one is to use an iframe to continuously refresh the page and read the user's records from the database.

MySQL has strong concurrency and fast response speed, and is a database software with excellent performance; PHP is a powerful server-side scripting language. In the website development of Shanxi Aluminum Factory, the author used PHP4.0+MySQL3.23.38 to establish a variety of applications. Next, take a simple chat room design as an example to introduce the application of PHP+MySQL in web development.

1. Overall design

 1.1 Conception and planning:

The basic principle of the chat room is to store the speech data sent by each user connected to the same web page, and then transmit all the speech data to each user. In other words, the function of a chat room is realized by using a database to collect everyone's speeches and transmitting the data in the database to everyone.

 1.2 Table design

First use MySQL to create a table chat to store user comments:

The code is as follows Copy code
 代码如下 复制代码

mysql> CREATE TABLE chat
-> (chtime DATATIME,
-> nick CHAR(10) NOT NULL,
->words CHAR(150));

mysql> CREATE TABLE chat

-> (chtime DATATIME,
->nick CHAR(10) NOT NULL,

->words CHAR(150));

Only three fields are set in the table. chtime is the time of speech, nick is the nickname of the speaker, words is the content of the speech, and the speech can be up to 150 characters

 1.3 Web Design

The simplest chat room usually requires two page frames: one page frame is the form for users to enter comments, and the other is used to display everyone's comments. So the code segment usually requires at least the following segments:

Create the structure of the page frame (main.php)

Display the program segment where everyone speaks (cdisplay.php)

Transmit the user's speech program segment (speak.php)

User login to enter the chat room program segment (login.php)

 2. Code design

After the above planning is completed, you can start code design. Using PHP can realize the above functions very simply.

 代码如下 复制代码
<html>
<head>
 <title>用户登录</title>
</head>
<body>请输入您的昵称<br>
<form action=”main.php” method=”post” target=”_self”>
 <input type=”text” name=”nick” cols=”20”>
 <input type=”submit” value=”登录”>
</body>
</html>
 2.1 User login login.php, this code is a complete HTML web page


The code is as follows Copy code
<html>

<head>

<title>User login</title>

</head>

<body>Please enter your nickname<br>
 代码如下 复制代码

<?
 setcookie(“nick”,$nick) //用cookie记录用户昵称,是常用的传递变量方法
?>

<html>
<title>山西铝厂聊天室试用版ver1.0</title>
<frameset rows=”80%,*”>
<frame src=” cdisplay.php” name=”chatdisplay”>
<frame src=”speak.php” name=”speak”>
</frameset>
</html>

<form action=”main.php” method=”post” target=”_self”> <input type=”text” name=”nick” cols=”20”> <input type=”submit” value=”Login”> </body> </html>
After the user submits his nickname, he enters the chat room, and the following processing is handled by main.php.  2.2 Main code segment of page frame main.php:
The code is as follows Copy code
<? setcookie(“nick”,$nick) //Use cookies to record user nicknames, which is a commonly used method of passing variables ?> <html> <title>Shanxi Aluminum Factory Chat Room Trial Version ver1.0</title> <frameset rows=”80%,*”> <frame src=” cdisplay.php” name=”chatdisplay”> <frame src=”speak.php” name=”speak”> </frameset> </html>


2.3 Display speech cdisplay.php

The task of this code segment is to extract the data from the chat table and display it in the page frame. Each time it is refreshed, the 15 most recent statements in the database are fetched. At the same time, in order to prevent the database from growing indefinitely, it is necessary to design the function of deleting old data. The code is as follows

​$str=”select * from chat ORDER BY chtime;”; //Query string ​$result=mysql_query($str, $link_ID); //Send query
The code is as follows
 代码如下 复制代码
<html>
<head>
 <title>显示用户发言</title>
 <meta http-equiv=”refresh” content=”5;url=cdisplay.php”>
</head>
<body>
<?
 $link_ID=mysql_connect(“main”,”root”);
 //链接Mysql服务器 服务器名为main,管理员名为root
 mysql_select_db(“abc”); //选择数据库
 $str=”select * from chat ORDER BY chtime;” ; //查询字符串
 $result=mysql_query($str, $link_ID); //送出查询
 $rows=mysql_num_rows($result); //取得查询结果的记录笔数
 //取得最后15笔发言,并显示
 @mysql_data_seek($resut,$rows-15); //移动记录指针到前15笔记录
 if ($rows<15) $l=$rows; else $l=15; //记录总数小于15,则最多为该记录数
 for ($i=1;$i<=$l;$i++) {
  list($chtime,$nick,$words)=mysql_fetch_row($result);
  echo $chtime; echo “ “;echo $nick; echo”:” ; echo $words; echo “<BR>”;
 }
 //清除库中过时的数据
 @mysql_data_seek($result,$rows-20); //移动记录指针到前20笔记录
 list($limtime)=mysql_fetch_row($result);
 $str=”DELETE FROM chat WHERE chtime<’$limtime’ ;” ;
 $result=mysql_query($str,$link_ID); //送出查询字符串,库中只留前20个记录
 mysql_close($link_ID);
?>
</body>
</html>
Copy code

<html>

<head>

<title>Display user comments</title>
 代码如下 复制代码
<html>
<head>
 <title>发言</title>
</head>
<body>
<?
 If ($words)
  { $link_ID=mysql_connect(“main”,”root”);
  mysql_select_db(“abc”); //数据库名为abc
  $time=date(y).date(m).date(d).date(h).date(i).(date(s); //取得当前时间
  $str=”INSERT INTO chat(chtime,nick,words) values
    (‘$time’,’$nick’,’$words’);” ;
  mysql_query($str,$link_ID); //送出发言到数据库
  mysql_close($link_ID);
 }
?>
<meta http-equiv=”refresh” content=”5;url=cdisplay.php”>

</head>

<body>
 代码如下 复制代码

<form action=”speak.php” method=”post” target=” _self”>
 <input type=”text” name=”words” cols=”20”>
 <input type=”submit” value=”发言”>
</form>
</body>
</html>

<?

​$link_ID=mysql_connect("main","root");
//Link to the Mysql server. The server name is main, and the administrator name is root

mysql_select_db("abc"); //Select database
​$rows=mysql_num_rows($result); //The number of records obtained from the query results //Get the last 15 comments and display @mysql_data_seek($resut,$rows-15); //Move the record pointer to the first 15 records if ($rows<15) $l=$rows; else $l=15; //The total number of records is less than 15, then the maximum number of records is for ($i=1;$i<=$l;$i++) { list($chtime,$nick,$words)=mysql_fetch_row($result); echo $chtime; echo “ “;echo $nick; echo”:” ; echo $words; echo “<BR>”; } //Clear outdated data in the library @mysql_data_seek($result,$rows-20); //Move the record pointer to the first 20 records list($limtime)=mysql_fetch_row($result); ​$str=”DELETE FROM chat WHERE chtime<’$limtime’ ;” ; ​$result=mysql_query($str,$link_ID); //Send the query string, leaving only the first 20 records in the library ​mysql_close($link_ID); ?> </body> </html> 2.4 Send speech to database speak.php
The code is as follows Copy code
<html> <head> <title>Speech</title> </head> <body> <? If ($words) ​{ $link_ID=mysql_connect("main","root"); mysql_select_db("abc"); //The database name is abc ​$time=date(y).date(m).date(d).date(h).date(i).(date(s); //Get the current time ​$str=”INSERT INTO chat(chtime,nick,words) values ​​(‘$time’,’$nick’,’$words’);” ; mysql_query($str,$link_ID); //Send the statement to the database mysql_close($link_ID); } ?> //Input form to speak
The code is as follows Copy code
<form action=”speak.php” method=”post” target=”_self”> <input type=”text” name=”words” cols=”20”> <input type=”submit” value=”Speak”> </form> </body> </html> After completing the above work, a simple chat room is completed

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/631641.htmlTechArticleChat rooms can be implemented by many programs, and the principle is simple. It can be implemented without refreshing. The simplest one is to use a The iframe keeps refreshing the page and reading the user's records from the database...
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Repo: How To Revive Teammates
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

PHP 8.4 Installation and Upgrade guide for Ubuntu and Debian PHP 8.4 Installation and Upgrade guide for Ubuntu and Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

How to fix mysql_native_password not loaded errors on MySQL 8.4 How to fix mysql_native_password not loaded errors on MySQL 8.4 Dec 09, 2024 am 11:42 AM

One of the major changes introduced in MySQL 8.4 (the latest LTS release as of 2024) is that the "MySQL Native Password" plugin is no longer enabled by default. Further, MySQL 9.0 removes this plugin completely. This change affects PHP and other app

How To Set Up Visual Studio Code (VS Code) for PHP Development How To Set Up Visual Studio Code (VS Code) for PHP Development Dec 20, 2024 am 11:31 AM

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

How do you parse and process HTML/XML in PHP? How do you parse and process HTML/XML in PHP? Feb 07, 2025 am 11:57 AM

This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

PHP Program to Count Vowels in a String PHP Program to Count Vowels in a String Feb 07, 2025 pm 12:12 PM

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

7 PHP Functions I Regret I Didn't Know Before 7 PHP Functions I Regret I Didn't Know Before Nov 13, 2024 am 09:42 AM

If you are an experienced PHP developer, you might have the feeling that you’ve been there and done that already.You have developed a significant number of applications, debugged millions of lines of code, and tweaked a bunch of scripts to achieve op

Top 10 PHP CMS Platforms For Developers in 2024 Top 10 PHP CMS Platforms For Developers in 2024 Dec 05, 2024 am 10:29 AM

CMS stands for Content Management System. It is a software application or platform that enables users to create, manage, and modify digital content without requiring advanced technical knowledge. CMS allows users to easily create and organize content

How to Add Elements to the End of an Array in PHP How to Add Elements to the End of an Array in PHP Feb 07, 2025 am 11:17 AM

Arrays are linear data structures used to process data in programming. Sometimes when we are processing arrays we need to add new elements to the existing array. In this article, we will discuss several ways to add elements to the end of an array in PHP, with code examples, output, and time and space complexity analysis for each method. Here are the different ways to add elements to an array: Use square brackets [] In PHP, the way to add elements to the end of an array is to use square brackets []. This syntax only works in cases where we want to add only a single element. The following is the syntax: $array[] = value; Example

See all articles