WebRTC (Web Real-Time Communication) is an open-source technology that enables real-time communication via simple APIs in web browsers and mobile apps. It allows audio, video, and data sharing directly between peers without needing an intermediary server, making it perfect for applications like video conferencing, live streaming, and file sharing.
In this blog, we'll dive into the following topics:
WebRTC is a set of standards and protocols that enables real-time audio, video, and data communication between web browsers. It includes several key components:
WebRTC is a client-side technology and does not require a specific server installation. However, you will need a web server to serve your HTML and JavaScript files. For local development, you can use a simple HTTP server.
Install Node.js: Download and install Node.js from nodejs.org.
Create a Project Directory: Open a terminal and create a new directory for your project.
mkdir webrtc-project cd webrtc-project
Initialize a Node.js Project:
npm init -y
Install HTTP Server:
npm install --save http-server
Create Your Project Files:
Create an index.html file with the following content:
```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>WebRTC Example</title> </head> <body> <h1>WebRTC Example</h1> <video id="localVideo" autoplay muted></video> <video id="remoteVideo" autoplay></video> <script src="main.js"></script> </body> </html> ```
We'll create a simple peer-to-peer video call application. This example will use two browser tabs to simulate the peer connection.
Capture Local Video: Use getUserMedia to capture video from the user's camera.
Create Peer Connection: Establish a peer connection between the local and remote peers.
Exchange Offer and Answer: Use SDP (Session Description Protocol) to exchange connection details.
Handle ICE Candidates: Exchange ICE candidates to establish the connection.
Create a main.js file with the following content:
const localVideo = document.getElementById('localVideo'); const remoteVideo = document.getElementById('remoteVideo'); let localStream; let peerConnection; const serverConfig = { iceServers: [{ urls: 'stun:stun.l.google.com:19302' }] }; const constraints = { video: true, audio: true }; // Get local video stream navigator.mediaDevices.getUserMedia(constraints) .then(stream => { localStream = stream; localVideo.srcObject = stream; setupPeerConnection(); }) .catch(error => { console.error('Error accessing media devices.', error); }); function setupPeerConnection() { peerConnection = new RTCPeerConnection(serverConfig); // Add local stream to the peer connection localStream.getTracks().forEach(track => peerConnection.addTrack(track, localStream)); // Handle remote stream peerConnection.ontrack = event => { remoteVideo.srcObject = event.streams[0]; }; // Handle ICE candidates peerConnection.onicecandidate = event => { if (event.candidate) { sendSignal({ 'ice': event.candidate }); } }; // Create an offer and set local description peerConnection.createOffer() .then(offer => { return peerConnection.setLocalDescription(offer); }) .then(() => { sendSignal({ 'offer': peerConnection.localDescription }); }) .catch(error => { console.error('Error creating an offer.', error); }); } // Handle signals (for demo purposes, this should be replaced with a signaling server) function sendSignal(signal) { console.log('Sending signal:', signal); // Here you would send the signal to the other peer (e.g., via WebSocket) } function receiveSignal(signal) { if (signal.offer) { peerConnection.setRemoteDescription(new RTCSessionDescription(signal.offer)) .then(() => peerConnection.createAnswer()) .then(answer => peerConnection.setLocalDescription(answer)) .then(() => sendSignal({ 'answer': peerConnection.localDescription })); } else if (signal.answer) { peerConnection.setRemoteDescription(new RTCSessionDescription(signal.answer)); } else if (signal.ice) { peerConnection.addIceCandidate(new RTCIceCandidate(signal.ice)); } } // Simulate receiving a signal from another peer // This would typically be handled by a signaling server setTimeout(() => { receiveSignal({ offer: { type: 'offer', sdp: '...' // SDP offer from the other peer } }); }, 1000);
The above is the detailed content of Introduction to WebRTC. For more information, please follow other related articles on the PHP Chinese website!