WebRTC - Envoi de messages
Créons maintenant un exemple simple. Tout d'abord, exécutez le serveur de signalisation que nous avons créé dans le didacticiel «serveur de signalisation» via «serveur de nœuds».
Il y aura trois entrées de texte sur la page, une pour une connexion, une pour un nom d'utilisateur et une pour le message que nous voulons envoyer à l'autre pair. Créez un fichier index.html et ajoutez le code suivant -
<html lang = "en">
<head>
<meta charset = "utf-8" />
</head>
<body>
<div>
<input type = "text" id = "loginInput" />
<button id = "loginBtn">Login</button>
</div>
<div>
<input type = "text" id = "otherUsernameInput" />
<button id = "connectToOtherUsernameBtn">Establish connection</button>
</div>
<div>
<input type = "text" id = "msgInput" />
<button id = "sendMsgBtn">Send text message</button>
</div>
<script src = "client.js"></script>
</body>
</html>
Nous avons également ajouté trois boutons pour la connexion, l'établissement d'une connexion et l'envoi d'un message. Créez maintenant un fichier client.js et ajoutez le code suivant -
var connection = new WebSocket('ws://localhost:9090');
var name = "";
var loginInput = document.querySelector('#loginInput');
var loginBtn = document.querySelector('#loginBtn');
var otherUsernameInput = document.querySelector('#otherUsernameInput');
var connectToOtherUsernameBtn = document.querySelector('#connectToOtherUsernameBtn');
var msgInput = document.querySelector('#msgInput');
var sendMsgBtn = document.querySelector('#sendMsgBtn');
var connectedUser, myConnection, dataChannel;
//when a user clicks the login button
loginBtn.addEventListener("click", function(event) {
name = loginInput.value;
if(name.length > 0) {
send({
type: "login",
name: name
});
}
});
//handle messages from the server
connection.onmessage = function (message) {
console.log("Got message", message.data);
var data = JSON.parse(message.data);
switch(data.type) {
case "login":
onLogin(data.success);
break;
case "offer":
onOffer(data.offer, data.name);
break;
case "answer":
onAnswer(data.answer);
break;
case "candidate":
onCandidate(data.candidate);
break;
default:
break;
}
};
//when a user logs in
function onLogin(success) {
if (success === false) {
alert("oops...try a different username");
} else {
//creating our RTCPeerConnection object
var configuration = {
"iceServers": [{ "url": "stun:stun.1.google.com:19302" }]
};
myConnection = new webkitRTCPeerConnection(configuration, {
optional: [{RtpDataChannels: true}]
});
console.log("RTCPeerConnection object was created");
console.log(myConnection);
//setup ice handling
//when the browser finds an ice candidate we send it to another peer
myConnection.onicecandidate = function (event) {
if (event.candidate) {
send({
type: "candidate",
candidate: event.candidate
});
}
};
openDataChannel();
}
};
connection.onopen = function () {
console.log("Connected");
};
connection.onerror = function (err) {
console.log("Got error", err);
};
// Alias for sending messages in JSON format
function send(message) {
if (connectedUser) {
message.name = connectedUser;
}
connection.send(JSON.stringify(message));
};
Vous pouvez voir que nous établissons une connexion socket avec notre serveur de signalisation. Lorsqu'un utilisateur clique sur le bouton de connexion, l'application envoie son nom d'utilisateur au serveur. Si la connexion réussit, l'application crée l' objet RTCPeerConnection et configure le gestionnaire onicecandidate qui envoie tous les candidats glacés trouvés à l'autre homologue. Il exécute également la fonction openDataChannel () qui crée un dataChannel. Notez que lors de la création de l'objet RTCPeerConnection, le deuxième argument du constructeur est facultatif: [{RtpDataChannels: true}] est obligatoire si vous utilisez Chrome ou Opera. L'étape suivante consiste à créer une offre à l'autre pair. Ajoutez le code suivant à vos Client.js Fichier-
//setup a peer connection with another user
connectToOtherUsernameBtn.addEventListener("click", function () {
var otherUsername = otherUsernameInput.value;
connectedUser = otherUsername;
if (otherUsername.length > 0) {
//make an offer
myConnection.createOffer(function (offer) {
console.log();
send({
type: "offer",
offer: offer
});
myConnection.setLocalDescription(offer);
}, function (error) {
alert("An error has occurred.");
});
}
});
//when somebody wants to call us
function onOffer(offer, name) {
connectedUser = name;
myConnection.setRemoteDescription(new RTCSessionDescription(offer));
myConnection.createAnswer(function (answer) {
myConnection.setLocalDescription(answer);
send({
type: "answer",
answer: answer
});
}, function (error) {
alert("oops...error");
});
}
//when another user answers to our offer
function onAnswer(answer) {
myConnection.setRemoteDescription(new RTCSessionDescription(answer));
}
//when we got ice candidate from another user
function onCandidate(candidate) {
myConnection.addIceCandidate(new RTCIceCandidate(candidate));
}
Vous pouvez voir que lorsqu'un utilisateur clique sur le bouton «Établir la connexion», l'application fait une offre SDP à l'autre pair. Nous avons également défini les gestionnaires onAnswer et onCandidate . Enfin, implémentons la fonction openDataChannel () qui crée notre dataChannel. Ajoutez le code suivant à votre fichier client.js -
//creating data channel
function openDataChannel() {
var dataChannelOptions = {
reliable:true
};
dataChannel = myConnection.createDataChannel("myDataChannel", dataChannelOptions);
dataChannel.onerror = function (error) {
console.log("Error:", error);
};
dataChannel.onmessage = function (event) {
console.log("Got message:", event.data);
};
}
//when a user clicks the send message button
sendMsgBtn.addEventListener("click", function (event) {
console.log("send message");
var val = msgInput.value;
dataChannel.send(val);
});
Ici, nous créons le dataChannel pour notre connexion et ajoutons le gestionnaire d'événements pour le bouton «envoyer un message». Maintenant, ouvrez cette page dans deux onglets, connectez-vous avec deux utilisateurs, établissez une connexion et essayez d'envoyer des messages. Vous devriez les voir dans la sortie de la console. Notez que l'exemple ci-dessus est testé dans Opera.
Vous pouvez maintenant voir que RTCDataChannel est une partie extrêmement puissante de l'API WebRTC. Il existe de nombreux autres cas d'utilisation de cet objet, comme le jeu peer-to-peer ou le partage de fichiers basé sur torrent.