Accéder aux serveurs locaux et aux instances Chrome avec le transfert de port

Meggin Kearney
Meggin Kearney
Sofia Emelianova
Sofia Emelianova

Vous pouvez utiliser le transfert de port pour:

  • Cas 1 Déboguer un onglet ouvert sur une autre instance de Chrome
  • Cas 2 Hébergez un site sur le serveur Web d'un ordinateur de développement, puis accédez au contenu à partir d'un appareil Android via un câble USB.

Dans le cas 2, le transfert de port fonctionne via un port TCP d'écoute sur votre appareil Android qui correspond à un port TCP de votre ordinateur de développement. Le trafic entre les ports passe par la connexion USB entre votre appareil Android et votre ordinateur de développement. La connexion ne dépend donc pas de la configuration de votre réseau.

De plus, si votre serveur Web utilise un domaine personnalisé, vous pouvez configurer votre appareil Android pour qu'il accède au contenu de ce domaine à l'aide du mappage de domaine personnalisé.

Configurer le transfert de port

Suivez les étapes ci-dessous en fonction de votre situation.

Cas 1: configurer le transfert de port vers une autre instance Chrome

  1. Exécutez une autre instance de Chrome avec le paramètre --remote-debugging-port=PORT, par exemple :

    MacOS

    open -a "Google Chrome" --args --remote-debugging-port=PORT

    Windows

    start chrome --remote-debugging-port=PORT

    Linux

    google-chrome --remote-debugging-port=PORT
  2. Dans l'instance Chrome que vous utilisez pour le débogage :

    1. Ouvrez chrome://inspect/#devices.
    2. Assurez-vous que l'option Case à cocher. Découvrir des cibles de réseau est cochée.
    3. Cliquez sur Configurer à côté de la case à cocher.
    4. Dans Paramètres de découverte des cibles, saisissez localhost:PORT, cochez la case Case à cocher. Activer le transfert de port, puis cliquez sur OK.

      Fenêtre des paramètres de découverte cible.

    5. De retour dans Devices (Appareils), vous verrez une nouvelle cible distante. Cliquez sur Inspecter à côté de l'onglet que vous souhaitez déboguer.

      Lien d'inspection à côté de l'onglet de la cible distante.

  3. Une nouvelle fenêtre DevTools en mode appareil s'ouvre. Dans la barre d'adresse en haut de l'écran, vous pouvez saisir l'adresse du site Web que vous souhaitez déboguer.

    Outils de développement en mode Appareil

  4. À côté de la barre d'adresse, vous pouvez activer/désactiver les modes de saisie.

Scénario 2: Configurer le transfert de port via USB pour votre appareil Android

  1. Configurez le débogage à distance entre votre ordinateur de développement et votre appareil Android. Lorsque vous avez terminé, votre appareil Android devrait apparaître dans la liste.

    L'appareil Android dans la liste.

  2. Assurez-vous que l'option Case à cocher. Découvrir les appareils USB est cochée.

  3. Cliquez sur Transfert de port à côté de la case à cocher.

  4. Dans Paramètres de transfert de port, localhost:8080 est configuré par défaut. Cochez Enable port forwarding (Activer le transfert de port).

    Paramètres de transfert de port..

  5. Si vous souhaitez configurer d'autres ports, suivez les étapes ci-dessous. Sinon, ignorez ces étapes et cliquez sur OK.

  6. Dans le champ de texte Port situé à gauche, saisissez le numéro de port à partir duquel vous souhaitez accéder au site sur votre appareil Android. Par exemple, si vous souhaitez accéder au site à partir de localhost:5000, saisissez 5000.

  7. Dans le champ de texte Adresse IP et port à droite, saisissez l'adresse IP ou le nom d'hôte sur lequel votre site s'exécute sur le serveur Web de votre ordinateur de développement, suivi du numéro de port. Par exemple, si votre site est exécuté sur localhost:5000, vous devez saisir localhost:5000.

  8. Cliquez sur OK.

Le transfert de port est maintenant configuré. Un indicateur d'état du transfert de port s'affiche en haut et à côté du nom de l'appareil.

État du transfert de port.

Pour afficher le contenu, ouvrez Chrome sur votre appareil Android et accédez au port localhost que vous avez spécifié dans le champ Port de l'appareil. Par exemple, si vous avez saisi 5000 dans le champ, vous devez accéder à localhost:5000.

Mappage sur des domaines locaux personnalisés

Le mappage de domaine personnalisé vous permet d'afficher le contenu d'un appareil Android à partir d'un serveur Web sur votre ordinateur de développement qui utilise un domaine personnalisé.

Par exemple, supposons que votre site utilise une bibliothèque JavaScript tierce qui ne fonctionne que sur le domaine chrome.devtools de la liste d'autorisation. Vous devez donc créer une entrée dans votre fichier hosts sur votre ordinateur de développement pour mapper ce domaine sur localhost (c'est-à-dire 127.0.0.1 chrome.devtools). Après avoir configuré le mappage de domaine personnalisé et le transfert de port, vous pourrez afficher le site sur votre appareil Android à l'URL chrome.devtools.

Configurer le transfert de port vers le serveur proxy

Pour mapper un domaine personnalisé, vous devez exécuter un serveur proxy sur votre ordinateur de développement. Charles, Squid et Fiddler sont des exemples de serveurs proxy.

Pour configurer le transfert de port vers un proxy:

  1. Exécutez le serveur proxy et notez le port qu'il utilise.

  2. Configurez le transfert de port sur votre appareil Android. Dans le champ local address (Adresse locale), saisissez localhost: suivi du port sur lequel votre serveur proxy s'exécute. Par exemple, s'il s'exécute sur le port 8000, vous devez saisir localhost:8000. Dans le champ device port (port de l'appareil), saisissez le numéro sur lequel votre appareil Android doit écouter, par exemple 3333.

Configurer les paramètres de proxy sur votre appareil

Vous devez ensuite configurer votre appareil Android pour qu'il communique avec le serveur proxy.

  1. Sur votre appareil Android, accédez à Paramètres > Wi-Fi.
  2. Appuyez de manière prolongée sur le nom du réseau auquel vous êtes connecté.

  3. Appuyez sur Modifier le réseau.

  4. Appuyez sur Options avancées. Les paramètres du proxy s'affichent.

  5. Appuyez sur le menu Proxy et sélectionnez Manuel.

  6. Dans le champ Nom d'hôte du proxy, saisissez localhost.

  7. Dans le champ Port du proxy, saisissez le numéro de port que vous avez indiqué pour le port de l'appareil dans la section précédente.

  8. Appuyez sur Enregistrer.

Avec ces paramètres, votre appareil transmet toutes ses requêtes au proxy de votre ordinateur de développement. Le proxy envoie des requêtes au nom de votre appareil. Les requêtes adressées à votre domaine local personnalisé sont donc correctement résolues.

Vous pouvez désormais accéder aux domaines personnalisés sur votre appareil Android Android comme vous le feriez sur l'ordinateur de développement.

Si votre serveur Web s'exécute sur un port non standard, n'oubliez pas de spécifier le port lorsque vous demandez le contenu à partir de votre appareil Android. Par exemple, si votre serveur Web utilise le domaine personnalisé chrome.devtools sur le port 7331, vous devez utiliser l'URL chrome.devtools:7331 lorsque vous consultez le site depuis votre appareil Android.