IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Angular Discussion :

Utiliser la même socket dans tous les components


Sujet :

Angular

  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2015
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2015
    Messages : 22
    Par défaut Utiliser la même socket dans tous les components
    Bonjour,
    J'ai de multiples connexions pour un même utilisateur alors que je devrais en avoir qu'une.
    J'ai un serveur node js qui utilise les socket io :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    const express = require('express')
    const app = express();
    const path = require('path');
     
    const http = require('http');
    const server = http.Server(app);
     
    const socketIO = require('socket.io');
    const io = socketIO(server);
     
    const port = process.env.PORT || 3000;
     
    app.use(express.static(path.join('D:/Did/socketDid/dist/socketDid')));
     
    app.get('/', function(req,res) {
    	res.sendFile('D:/Did/socketDid/src/index.html');
    })
     
    io.on('connection', (socket) => {
        console.log('user connected');
        socket.on('disconnect',() => {
        	console.log('user disconnected');
        })
     
    server.listen(port, () => {
        console.log(`started on port: ${port}`);
    });
    J'ai créée un webSocketService dans mon projet angular :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    import { Injectable } from '@angular/core';
    import { Observable, Subscriber } from 'rxjs';
    import * as io from 'socket.io-client';
     
    @Injectable({
      providedIn: 'root'
    })
    export class WebSocketServiceService {
     
      socket: any;
     
      constructor() { 
        if(null == this.socket) {
          this.socket = io();
        }
      }
     
      listen(eventName: string) {
        return new Observable((Subscriber) => {
          this.socket.on(eventName, (data) => {
            Subscriber.next(data);
          })
        });
      }
     
      emit(eventName: string, data: any) {
        this.socket.emit(eventName,data);
      }
    }
    et je l'ai rajouté dans le app.module
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    providers: [WebSocketServiceService],
    Dans chacun de mes components, je dois utiliser ce service pour utiliser la socket. Voici comment je déclare le service dans un component :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
     
    @Component({
      selector: 'app-connection-login',
      templateUrl: './connection-login.component.html',
      styleUrls: ['./connection-login.component.css'],
      providers: [WebSocketServiceService]
    })
    export class ConnectionLoginComponent implements OnInit {
      constructor(private webSocketService: WebSocketServiceService, private router: Router) { }
    .....
    Le problème est que pour chaque déclaration de ce service dans un component, j'ai une connexion supplémentaire... (je n'ai qu'une fenêtre d'ouverte) et je voudrais éviter ça.
    Comment faire pour partager la même socket pour un client donné ?


  2. #2
    Membre extrêmement actif
    Avatar de dukoid
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2012
    Messages
    2 100
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2012
    Messages : 2 100
    Par défaut
    Quand tu déclares un service au niveau des composants comme tu l'as fait ici
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    @Component({
      selector: 'app-connection-login',
      templateUrl: './connection-login.component.html',
      styleUrls: ['./connection-login.component.css'],
      providers: [WebSocketServiceService]
    })
    export class ConnectionLoginComponent implements OnInit {
    la classe WebSocketServiceService est instancié uniquement pour ce composant.
    donc pour tous les composants, tu auras à chaque fois une nouvelle instance

    Angular propose de déclarer un service au niveau d'un module.
    la solution la plus simple est de mettre le service dans providers du module racine: app.module.ts
    ainsi ce service sera instancié qu'une seule fois au niveau le plus haut et sera injecté dans tous les composants (DI - injection dépendance) qui le demande (présent dans le constructeur des composants)
    (et bien sur, supprimer ce service de tous les providers des composants)


    la meilleure pratique serai de paramétrer plus finement en créant un module qui regroupe les composants en question et ce module intégrera le service dans le providers
    (au lieu de l’intégrer au plus au niveau, après tout, peut être que tous les composants du projet n'ont pas besoin du service webSocket mais bon c'est du détail....)

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2015
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2015
    Messages : 22
    Par défaut
    Merci c'était si simple

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 10
    Dernier message: 25/05/2017, 17h11
  2. Mots clés utilisables dans tous les SGBD et norme SQL ?
    Par BIOoOAG dans le forum Langage SQL
    Réponses: 16
    Dernier message: 31/10/2014, 11h56
  3. Réponses: 7
    Dernier message: 29/05/2013, 17h23
  4. [AC-2007] Copie d'un champ dans tous les enregistrements (même champ)
    Par toumack dans le forum IHM
    Réponses: 6
    Dernier message: 26/09/2009, 23h31
  5. Pour qu'un logiciel ne soit utiliser dans tous les sessions
    Par mouloudéen dans le forum Autres Logiciels
    Réponses: 10
    Dernier message: 14/12/2005, 19h10

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo