Home >Backend Development >PHP Tutorial >php minimize data transfer: store data on client side
Exporting programs to other languages is one of the things programmers love, and on the WEB we have
Two different programming environments: client (browser) and server side, according to the definition of HTTP protocol,
We can write server programs that output other languages on the client. We chose as the server
Server-side language and JavaScript are used as client output. In this question we will show you how to use
The solution stores the data on the client side and displays it in chat rooms, news systems or anywhere else you want
The implemented application achieves minimal data transmission between the server and the client (browser).
Requesting support from:
php4
Javascript
Frames
Main idea:
We have been trying to use PHP to develop a chat room based on HTTP protocol (HTTP CHAT ROOM),
Although the HTTP protocol is not a good protocol for chatting, it is not affected by firewalls or proxies,
PHP can completely implement this function without using JAVA APPLETS. There are two main problems with chat rooms:
First, since IE does not support SERVER PUSH technology, we can only use CLIENT PULL technology (both
Automatic refresh on the client), the second problem is even deeper: because the idea is to refresh on the client, so the server
The server must transmit all messages every time, which means a large amount of data transmission, which is also the main cause of chat room delay
For the main reasons, this article attempts to solve the problem:
Using frames technology (frames) you can refresh the specified page without having to reload other pages, which can
To reduce the amount of service/client (C/S) data transmission. Our model is based on this scheme.
"master" file: defines the framework structure
"Loader" page: Import data
"display" page: display data
In this solution, the "loder" box is automatically refreshed every "x" seconds - the idea is to store the data in the "master"
file, so that the "loder" page only needs to request data from the server that the client does not have. We use timestamp (timestamp)
Note each message to determine which messages must be sent to the client and which ones must not be transmitted. We use PHP4.0 session management (session)
Store the client's last updated timestamp so that the timestamp is visible to both the server and the client. When "loader" file
When data is received from the "master" file (note: the "master" file is large, but it is only transmitted once), refresh the display page ("diaplay")
The "display" page simply calls the javascript function named "displaymsgs()" in the "master" file to display the message. This function is displayed dynamically
The data stored in the "master" file, the following is the general flow chart:
1. The browser requests the "master" page (frame), the "master" page is transmitted from the server to the client (browser), and then "master"
The file generates the framework and transfers the "loader" and "display" pages to the client.
2. On the server side, the "loader" file will be analyzed: If the client does not define the "timestamp" session variable, the "loder" file will
Get all the data from the server and generate javascript code to save the data to the "master" file, and then save the "timestamp" variable as
session variable.
3. The "loder" page generates javascript code to refresh the "display" page.
4. The refresh request causes the "display" page to call the "diaplaymsgs()" javascript function to display data
5. Go back to step 2 every "x" seconds
We can think of it as follows:
================================================== ======
"master" file: very large, defines the displaymsgs() function and stores data and initial values.
"Loader" file: small, retrieves data from the server and generates javascript code
"display" file: very small, calling the "diaplaymsgs()" function of the "master" file
================================================== =======
Note: The "master" file is only sent once
"loder" and "display" files are refreshed every "x" seconds
“loder” may be very large when transmitted for the first time, but it will be very small in the future
The "diaplay" file remains unchanged
If you are still not clear about the above ideas, below we will set up a chat room to explain the method in detail. This chat room is just for a simple demonstration
So it may not be very useful, but you can definitely use this idea to build more complex chat rooms. Remember that this idea is not just for chat rooms. :)
First, please use the MySQL database form:
============================
create table testeable (
timestamp datetime,
);
============================
The "master" file is as follows:
================================================
lines=new Array();
function displaymsgs() {
for(i=0;i
display.document.write('
');
}