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 dans 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 est mappé sur un port TCP sur 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

Selon votre cas, suivez les étapes suivantes.

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 Target discovery settings (Paramètres de découverte de la cible), saisissez localhost:PORT, cochez Case à cocher. Enable port forwarding (Activer le transfert de port), puis cliquez sur Done (OK).

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

    5. De retour dans 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 pour les développeurs en mode appareil.

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

Cas 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. Votre appareil Android devrait s'afficher 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 suivantes. Sinon, ignorez ces étapes et cliquez sur OK.

  6. Dans le champ de texte Port de 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 depuis 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 s'exécute sur localhost:5000, saisissez 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 accéderez à localhost:5000.

Mappage sur des domaines locaux personnalisés

Le mappage de domaine personnalisé vous permet d'afficher du contenu sur 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 de la liste d'autorisation chrome.devtools. Vous créez donc 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 Adresse locale, saisissez localhost:, suivi du port sur lequel s'exécute votre serveur proxy. Par exemple, si elle s'exécute sur le port 8000, saisissez localhost:8000. Dans le champ 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, puis sélectionnez Manuel.

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

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

  8. Appuyez sur Enregistrer.

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

Vous pouvez désormais accéder aux domaines personnalisés sur votre appareil Android comme vous le feriez sur la machine 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.