Home Web Front-end JS Tutorial Getting started with socket.io in node.js_javascript class library

Getting started with socket.io in node.js_javascript class library

May 16, 2016 pm 04:51 PM
node.js socket.io

Introduction to websocket and other reverse ajax technologies

In real-time web applications, a common method is reverse Ajax. Definition of reverse Ajax:

Reverse Ajax (Reverse Ajax) is essentially a concept that can send data from the server to the client. In a standard HTTP Ajax request, data is sent to the server. Reverse Ajax can simulate an Ajax request in some specific ways. These methods will be discussed in this article. In this way, the server can send data to the server as quickly as possible. Client sends events (low latency communication).

Reverse Ajax technology mainly has two contents: one is that the server maintains the TCP connection until it has data to send to the client (can be implemented using loops and sleep), and the other is client js programming skills.

Websocket is a standard of HTML5 and is also an anti-ajax technology.

Socket.io implementation of reverse AJAX technology example

socket.io official introduction:

Socket.IO aims to make realtime apps possible in every browser and mobile device, blurring the differences between the different transport mechanisms. It's care-free realtime 100% in JavaScript. In order to provide realtime connectivity on every browser, Socket. IO selects the most capable transport at runtime, without it affecting the API. WebSocket Adobe® Flash® Socket AJAX long polling AJAX multipart streaming Forever Iframe JSONP Polling

Simply speaking, socket.io is a library based on nodejs, which packages multiple reverse ajax technologies and unifies the interface. At runtime, socket.io automatically selects the appropriate reverse ajax technology to interact with the socket.io server based on the browser's conditions. If technologies such as websocket are standards, then socket.io is an application.

Here’s how to install it (the author uses Linux Mint 16):

Install node.js:

Copy the code The code is as follows:
sudo apt-get install nodejs

Enter the command nodejs to enter shell mode.

Install npm:

Copy code The code is as follows:
sudo apt-get install npm

Install socket.io:
Copy the code The code is as follows:
sudo npm install socket.io

The installation package is stored in the ~/node_modules directory, and the client socket.io.js is stored in the ~/node_modules/socket.io/node_modules/socket.io-client/dist directory.

socket.io example

The following examples are from the official website and have been modified appropriately.

First create the server-side (server-side) code (file test.js):

Copy the code The code is as follows:

var io = require('socket.io').listen(8080);

io.sockets.on('connection', function (socket) {
socket.emit('news', { hello: 'world' });
socket.on('my other event' , function (data) {
console.log(data);
});
});


The server test.js is bound to port 8080. When a client connects When the server test.js is running, the server test.js sends the news command to the client and transmits the data { hello: 'world' }; when the server test.js receives the my other event command, it will call the callback function function (data) { console.log(data);} to process the received data data.

The author built an nginx server, which uses port 80 and the web root directory is /usr/share/nginx/html. Copy socket.io.min.js under ~/node_modules/socket.io/node_modules/socket.io-client/dist to the web root directory, and create the file index.php in the web root directory (as a client) , the content is as follows:

Copy code The code is as follows:


< ;head>



<script><br> var socket = io.connect('http://localhost:8080');<br> socket.on('news', function (data) {<br> console.log(data);<br> console .log(data["hello"]);<br> socket.emit('my other event', { my: 'data' });<br> });<br></script>


In the above code, the socket is bound to port 8080, which is bound to the server side. socket.on() specifies how to process the data corresponding to the received command when receiving the news command. socket.emit() sends the command and data to the server.

Run the server:

Copy the code The code is as follows:
$ nodejs test.js

Run the client and observe: Open the browser, enter http://127.0.0.1 to access index.php, and open firebug to view the information.

Getting started with socket.io in node.js_javascript class libraryThe above picture is from firebug, which shows that after the client index.php connects to the server test.js, it receives the data {hello: "world"} from the server test.js. At the same time, you can also see that the URL used by index.php to access the server is not simply http://localhost:8080.
Getting started with socket.io in node.js_javascript class library
The above figure shows the processing process of server-side test.js.
Getting started with socket.io in node.js_javascript class libraryThe picture above is the http header sent by the client index.php to the server test.js for the first time.
Getting started with socket.io in node.js_javascript class library

The picture above is the http header sent by client index.php to server test.js for the second time. The websocket specification is used.
Getting started with socket.io in node.js_javascript class libraryWhen the server test.js is turned off, the client index.php shows a lot of Aborted status (the red part).

Analysis is over.

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

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

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)

Detailed graphic explanation of the memory and GC of the Node V8 engine Detailed graphic explanation of the memory and GC of the Node V8 engine Mar 29, 2023 pm 06:02 PM

This article will give you an in-depth understanding of the memory and garbage collector (GC) of the NodeJS V8 engine. I hope it will be helpful to you!

An article about memory control in Node An article about memory control in Node Apr 26, 2023 pm 05:37 PM

The Node service built based on non-blocking and event-driven has the advantage of low memory consumption and is very suitable for handling massive network requests. Under the premise of massive requests, issues related to "memory control" need to be considered. 1. V8’s garbage collection mechanism and memory limitations Js is controlled by the garbage collection machine

Let's talk about how to choose the best Node.js Docker image? Let's talk about how to choose the best Node.js Docker image? Dec 13, 2022 pm 08:00 PM

Choosing a Docker image for Node may seem like a trivial matter, but the size and potential vulnerabilities of the image can have a significant impact on your CI/CD process and security. So how do we choose the best Node.js Docker image?

Let's talk in depth about the File module in Node Let's talk in depth about the File module in Node Apr 24, 2023 pm 05:49 PM

The file module is an encapsulation of underlying file operations, such as file reading/writing/opening/closing/delete adding, etc. The biggest feature of the file module is that all methods provide two versions of **synchronous** and **asynchronous**, with Methods with the sync suffix are all synchronization methods, and those without are all heterogeneous methods.

Node.js 19 is officially released, let's talk about its 6 major features! Node.js 19 is officially released, let's talk about its 6 major features! Nov 16, 2022 pm 08:34 PM

Node 19 has been officially released. This article will give you a detailed explanation of the 6 major features of Node.js 19. I hope it will be helpful to you!

Let's talk about the GC (garbage collection) mechanism in Node.js Let's talk about the GC (garbage collection) mechanism in Node.js Nov 29, 2022 pm 08:44 PM

How does Node.js do GC (garbage collection)? The following article will take you through it.

Let's talk about the event loop in Node Let's talk about the event loop in Node Apr 11, 2023 pm 07:08 PM

The event loop is a fundamental part of Node.js and enables asynchronous programming by ensuring that the main thread is not blocked. Understanding the event loop is crucial to building efficient applications. The following article will give you an in-depth understanding of the event loop in Node. I hope it will be helpful to you!

What should I do if node cannot use npm command? What should I do if node cannot use npm command? Feb 08, 2023 am 10:09 AM

The reason why node cannot use the npm command is because the environment variables are not configured correctly. The solution is: 1. Open "System Properties"; 2. Find "Environment Variables" -> "System Variables", and then edit the environment variables; 3. Find the location of nodejs folder; 4. Click "OK".

See all articles