Les extensions peuvent échanger des messages avec des applications natives à l'aide d'une API semblable aux autres API de transmission de messages. Les applications natives compatibles avec cette fonctionnalité doivent enregistrer un hôte de messagerie native pouvant communiquer avec l'extension. Chrome démarre l'hôte dans un processus distinct et communique avec lui à l'aide de flux d'entrée et de sortie standards.
Hôte de messagerie native
Pour enregistrer un hôte de messagerie native, l'application doit enregistrer un fichier qui définit la configuration de l'hôte de messagerie native.
Voici un exemple de fichier:
{
"name": "com.my_company.my_application",
"description": "My Application",
"path": "C:\\Program Files\\My Application\\chrome_native_messaging_host.exe",
"type": "stdio",
"allowed_origins": ["chrome-extension://knldjmfmopnpolahpmmgbagdohdnhkik/"]
}
Le fichier manifeste de l'hôte de messagerie natif doit être au format JSON valide et contenir les champs suivants:
name
- Nom de l'hôte de messagerie native. Les clients transmettent cette chaîne à
runtime.connectNative()
ouruntime.sendNativeMessage()
. Ce nom ne peut contenir que des caractères alphanumériques minuscules, des traits de soulignement et des points. Le nom ne doit pas commencer ni se terminer par un point, et un point ne doit pas être suivi d'un autre point. description
- Brève description de l'application.
path
- Chemin d'accès au binaire de l'hôte de messagerie native. Sous Linux et macOS, le chemin d'accès doit être absolu. Sous Windows, il peut être relatif au répertoire contenant le fichier manifeste. Le processus hôte est démarré avec le répertoire actuel défini sur le répertoire contenant le binaire hôte. Par exemple, si ce paramètre est défini sur
C:\Application\nm_host.exe
, il sera démarré avec le répertoire actuel "C:\Application". type
- Type d'interface utilisé pour communiquer avec l'hôte de messagerie natif. Ce paramètre a une valeur possible:
stdio
. Il indique que Chrome doit utiliserstdin
etstdout
pour communiquer avec l'hôte. allowed_origins
- Liste des extensions qui doivent avoir accès à l'hôte de messagerie native. Les valeurs
allowed-origins
ne peuvent pas contenir de caractères génériques.
Emplacement de l'hôte de messagerie native
L'emplacement du fichier manifeste dépend de la plate-forme.
Sous Windows, le fichier manifeste peut se trouver n'importe où dans le système de fichiers. L'installateur de l'application doit créer une clé de registre, HKEY_LOCAL_MACHINE\SOFTWARE\Google\Chrome\NativeMessagingHosts\com.my_company.my_application
ou HKEY_CURRENT_USER\SOFTWARE\Google\Chrome\NativeMessagingHosts\com.my_company.my_application
, et définir la valeur par défaut de cette clé sur le chemin d'accès complet au fichier manifeste. Par exemple, à l'aide de la commande suivante:
REG ADD "HKCU\Software\Google\Chrome\NativeMessagingHosts\com.my_company.my_application" /ve /t REG_SZ /d "C:\path\to\nmh-manifest.json" /f
ou à l'aide du fichier .reg
suivant:
Windows Registry Editor Version 5.00
[HKEY_CURRENT_USER\Software\Google\Chrome\NativeMessagingHosts\com.my_company.my_application]
@="C:\\path\\to\\nmh-manifest.json"
Lorsque Chrome recherche des hôtes de messagerie natifs, le Registre 32 bits est interrogé en premier, puis le Registre 64 bits.
Sous macOS et Linux, l'emplacement du fichier manifeste de l'hôte de messagerie native varie selon le navigateur (Google Chrome ou Chromium). Les hôtes de messagerie native à l'échelle du système sont recherchés à un emplacement fixe, tandis que les hôtes de messagerie native au niveau de l'utilisateur sont recherchés dans le sous-répertoire NativeMessagingHosts/
du répertoire de profil utilisateur.
- macOS (à l'échelle du système)
- Google Chrome:
/Library/Google/Chrome/NativeMessagingHosts/com.my_company.my_application.json
- Chromium:
/Library/Application Support/Chromium/NativeMessagingHosts/com.my_company.my_application.json
- macOS (propre à l'utilisateur, chemin d'accès par défaut)
- Google Chrome:
~/Library/Application Support/Google/Chrome/NativeMessagingHosts/com.my_company.my_application.json
- Chromium:
~/Library/Application Support/Chromium/NativeMessagingHosts/com.my_company.my_application.json
- Linux (tout le système)
- Google Chrome:
/etc/opt/chrome/native-messaging-hosts/com.my_company.my_application.json
- Chromium:
/etc/chromium/native-messaging-hosts/com.my_company.my_application.json
- Linux (chemin par défaut, spécifique à l'utilisateur)
- Google Chrome:
~/.config/google-chrome/NativeMessagingHosts/com.my_company.my_application.json
- Chromium:
~/.config/chromium/NativeMessagingHosts/com.my_company.my_application.json
Protocole de messagerie native
Chrome démarre chaque hôte de messagerie natif dans un processus distinct et communique avec lui à l'aide de l'entrée standard (stdin
) et de la sortie standard (stdout
). Le même format est utilisé pour envoyer des messages dans les deux sens. Chaque message est sérialisé à l'aide de JSON, encodé en UTF-8 et est précédé d'une longueur de message de 32 bits dans l'ordre d'octet natif. La taille maximale d'un seul message de l'hôte de messagerie natif est de 1 Mo, principalement pour protéger Chrome contre les applications natives qui ne fonctionnent pas correctement. La taille maximale du message envoyé à l'hôte de messagerie native est de 4 Go.
Le premier argument de l'hôte de messagerie natif est l'origine de l'appelant, généralement chrome-extension://[ID of allowed extension]
. Cela permet aux hôtes de messagerie native d'identifier la source du message lorsque plusieurs extensions sont spécifiées dans la clé allowed_origins
du fichier manifeste de l'hôte de messagerie native.
Sous Windows, l'hôte de messagerie native reçoit également un argument de ligne de commande avec un gestionnaire de la fenêtre native Chrome appelante: --parent-window=<decimal handle value>
. Cela permet à l'hôte de messagerie native de créer des fenêtres d'UI natives correctement parentées. Notez que cette valeur sera égale à 0 si le contexte d'appel est un service worker.
Lorsqu'un port de messagerie est créé à l'aide de runtime.connectNative()
, Chrome démarre le processus hôte de messagerie natif et le maintient en cours d'exécution jusqu'à ce que le port soit détruit. En revanche, lorsqu'un message est envoyé à l'aide de runtime.sendNativeMessage()
, sans créer de port de messagerie, Chrome lance un nouveau processus hôte de messagerie native pour chaque message. Dans ce cas, le premier message généré par le processus hôte est traité comme une réponse à la requête d'origine, et Chrome le transmettra au rappel de réponse spécifié lors de l'appel de runtime.sendNativeMessage()
. Dans ce cas, tous les autres messages générés par l'hôte de messagerie native sont ignorés.
Se connecter à une application native
L'envoi et la réception de messages à partir d'une application native et vers celle-ci sont très similaires à la messagerie inter-extensions. La principale différence est que runtime.connectNative()
est utilisé à la place de runtime.connect()
, et runtime.sendNativeMessage()
à la place de runtime.sendMessage()
.
Pour utiliser ces méthodes, l'autorisation "nativeMessaging" doit être déclarée dans le fichier manifeste de vos extensions.
Ces méthodes ne sont pas disponibles dans les scripts de contenu, mais uniquement dans les pages et le service worker de votre extension. Si vous souhaitez communiquer d'un script de contenu à l'application native, envoyez le message à votre service worker pour le transmettre à l'application native.
L'exemple suivant crée un objet runtime.Port
connecté à l'hôte de messagerie natif com.my_company.my_application
, commence à écouter les messages de ce port et envoie un message sortant:
var port = chrome.runtime.connectNative('com.my_company.my_application');
port.onMessage.addListener(function (msg) {
console.log('Received' + msg);
});
port.onDisconnect.addListener(function () {
console.log('Disconnected');
});
port.postMessage({text: 'Hello, my_application'});
Utilisez runtime.sendNativeMessage
pour envoyer un message à l'application native sans créer de port, par exemple :
chrome.runtime.sendNativeMessage(
'com.my_company.my_application',
{text: 'Hello'},
function (response) {
console.log('Received ' + response);
}
);
Déboguer la messagerie native
Lorsque certaines erreurs de messagerie native se produisent, la sortie est écrite dans le journal des erreurs de Chrome. Cela inclut lorsque l'hôte de messagerie native ne parvient pas à démarrer, écrit dans stderr
ou ne respecte pas le protocole de communication. Sur Linux et macOS, vous pouvez accéder à ce journal en démarrant Chrome à partir de la ligne de commande et en consultant sa sortie dans le terminal. Sous Windows, utilisez --enable-logging
comme expliqué dans la section Activer la journalisation.
Voici quelques erreurs courantes et des conseils pour les résoudre:
Échec du démarrage de l'hôte de messagerie native.
Vérifiez si vous disposez des autorisations suffisantes pour exécuter le fichier d'hôte de messagerie natif.
Nom d'hôte de messagerie native non valide spécifié.
Vérifiez si le nom contient des caractères non valides. Seuls les caractères alphanumériques en minuscules, les traits de soulignement et les points sont autorisés. Un nom ne peut pas commencer ni se terminer par un point, et un point ne peut pas être suivi d'un autre point.
L'hôte natif a quitté le système.
Le canal vers l'hôte de messagerie native a été interrompu avant que le message ne soit lu par Chrome. Cette opération est probablement lancée à partir de votre hôte de messagerie native.
L'hôte de messagerie native spécifié est introuvable.
Vérifiez les éléments suivants :
- Le nom est-il correctement orthographié dans l'extension et dans le fichier manifeste ?
- Le fichier manifeste se trouve-t-il dans le bon répertoire et avec le bon nom ? Pour connaître les formats attendus, consultez la section Emplacement de l'hôte de messagerie native.
- Le fichier manifeste est-il au bon format ? En particulier, le fichier JSON est-il valide et bien formé, et les valeurs correspondent-elles à la définition d'un fichier manifeste d'hôte de messagerie natif ?
- Le fichier spécifié dans
path
existe-t-il ? Sous Windows, les chemins d'accès peuvent être relatifs, mais sous macOS et Linux, ils doivent être absolus.
Le nom d'hôte de l'hôte de messagerie native n'est pas enregistré. (Windows uniquement)
Impossible de trouver l'hôte de messagerie native dans le Registre Windows. Vérifiez à l'aide de regedit
si la clé a bien été créée et si elle correspond au format requis, comme indiqué dans la section Emplacement de l'hôte de messagerie native.
L'accès à l'hôte de messagerie native spécifié est interdit.
L'origine de l'extension est-elle listée dans allowed_origins
?
Erreur lors de la communication avec l'hôte de messagerie natif.
Cela indique une implémentation incorrecte du protocole de communication dans l'hôte de messagerie natif.
- Assurez-vous que tous les résultats dans
stdout
respectent le protocole de messagerie native. Si vous souhaitez imprimer des données à des fins de débogage, écrivez àstderr
. - Assurez-vous que la longueur du message de 32 bits est au format d'entier natif de la plate-forme (little-endian/big-endian).
- La longueur du message ne doit pas dépasser 1 024*1 024.
- La taille du message doit être égale au nombre d'octets qu'il contient. Cela peut différer de la "longueur" d'une chaîne, car les caractères peuvent être représentés par plusieurs octets.
- Windows uniquement:assurez-vous que le mode E/S du programme est défini sur
O_BINARY
. Par défaut, le mode d'E/S estO_TEXT
, ce qui corrompt le format du message, car les retours à la ligne (\n
=0A
) sont remplacés par des fins de ligne Windows (\r\n
=0D 0A
). Le mode d'E/S peut être défini à l'aide de__setmode
.