Hands-on - Socket.io Parte 2

Escrito por

Continuando nossa série sobre Socket.io, vamos aprofundar um pouco mais no assunto. Lembrando nosso código do lado server:

1const app = require('express')()
2const http = require('http').createServer(app)
3const io = require('socket.io')(http)
4app.get('/', (req, res)=>{
5 res.sendFile(__dirname+'/index.html')
6})
7io.on('connection', (socket)=>{
8 console.log('New connection', socket.id)
9})
10http.listen(3000, function(){
11 console.log('listening on port 3000')
12})

Simplesmente estávamos tratando a conexão, então se o cliente conectou, isso nos era mostrado, além do ID da conexão. (Lembrando que cada Socket criado tem um ID diferente. Mesmo que o cliente abra duas abas com links da mesma sessão, elas são tratadas separadamente).

Vamos abrir o cliente e adicionar o Jquery _(apenas procure no Google jquery CDN, copiar a url e adicionar em source) e e_m seguida adicionar um socket.on. Com isso, sabemos do lado do cliente que foi conectado.

1<html>
2 <body>
3 <h1>Socket.io</h1>
4 <script src="/socket.io/socket.io.js"></script>
5 <script src="https://code.jquery.com/jquery-3.2.1.min.js"> </script>
6 <div id="msgs"></div>
7 <script>
8 const socket = io() socket.on('connect', function()
9 {$("msgs").append("connected with id: " + socket.id + "<br>")}
10 </script>
11 </body>
12</html>

E como isso será notificado?

Perceba que criamos uma DIV msgs para podermos colocar as mensagens dentro a medida que recebemos. Quando o cliente conectar nosso div msgs, irá chamar o append e mostrar a conexão com o ID utilizado. Assim, podemos, por exemplo, identificar o usuário baseado nesta conexão.

O que podemos fazer?

Quando o cliente se conectar, podemos mandar uma mensagem para o servidor, por exemplo, que o ID especifico está conectado. Adicionando no lado do cliente um socket emit dentro da function e mandamos escrever a msg gerado do lado servidor.

1<script>
2 const socket = io()
3 socket.on('connect', function(){
4 $("msgs").append('connected with id: '+socket.id+'<br>'
5 socket.emit('msg', 'I am connected '+socket.id);
6 )}
7 socket.on('msg', function(msg){
8 $("#msgs")append(msg+' <br>')
9 }
10</script>

E do lado servidor adicionando um gerenciador de evento para que, quando ele receber uma mensagem,possa só escrever por enquanto (apenas modificamos esta linha de código).

1io.on('connection', (socket)=>{
2 console.log('New connection', socket.id)
3}
4socket.on('msg', (msg)=>{
5 console.log(msg)
6 socket.broadcast.emit('msg', socket.id+' connected');
7})

Se reiniciarmos o servidor e gerarmos uma nova conexão do lado cliente, irá aparecer a mensagem de "I am connected + ID" do lado servidor, já que o Socket representa o cliente que está conectado. Depois com o broadcast estamos avisando todos que o ID específico foi conectado.

Não aconteceu nada. Está dando erro?

No lado cliente, abra uma nova aba, copie o link da sessão e rode, então verá que ele irá se conectar, mostrar um novo id, e na sessão anterior vai ser emitida uma mensagem que aquele ID foi conectado, como queríamos, afinal estávamos enviando para todos quando algum novo ID se conectasse.

Por que isso aconteceu?

Isso acontece porque o broadcast não manda a mensagem para o próprio Socket. Isso é feito para não permitir que não receba mensagens duplicadas.

Perceba que com isso já é possível criar um chat. Precisamos apenas adicionar ao lado cliente um input type text e criar um function keyDown, em seguida gerar um if dizendo que se o keyCode for igual ao número que representa o enter (no caso 13), vamos disparar a mensagem com o valor dentro do text.

1<html>
2 <body>
3 <h1>Socket.io</h1>
4 <script src="/socket.io/socket.io.js"></script>
5 <script src="https://code.jquery.com/jquery-3.2.1.min.js"> </script>
6 <div id="msgs"></div>
7 <input type="text" />
8 <script>
9 const socket = io()
10 socket.on('connect', function(){
11 $("msgs").append('connected with id: '+socket.id+'<br>'
12 socket.emit('msg', 'I am connected '+socket.id);
13 )}
14 socket.on('msg', function(msg){
15 $("#msgs")append(msg+' <br>')
16 }
17 $(function(){
18 $("imput").keyDown(function(key){
19 if(key.keyCode===13){
20 socket.emit('msg', $(this).val());
21 }
22 })
23 })
24 </script>
25 </body>
26</html>

Já do lado servidor, temos que pedir para enviar a mensagem do campo texto ao invés do socket.id, substituindo:

1socket.broadcast.emit("msg", socket.id + " connected")

Por:

1socket.broadcast.emit("msg", msg)

Confira todos os detalhes no vídeo:

Curta o DevPleno no Facebook, inscreva-se no canal e não se esqueça de cadastrar seu e-mail para não perder as novidades. Ah, fique à vontade para deixar suas dúvidas e sugestões nos comentários. Abraço!

Evolua mais rápido

Junte-se a milhares de desenvolvedores no nosso time de alunos premium e alcance mais rápido o próximo nível da sua carreira.

Ver cursos Premium