OneSignalSDKWorker.js) est un fichier JavaScript hébergé sur votre serveur, nécessaire pour les notifications push web. Il permet à votre site de recevoir et d’afficher des notifications, même lorsque l’utilisateur n’est pas sur votre page.

Configuration du service worker
Créez un fichierOneSignalSDKWorker.js dédié pour les notifications push OneSignal. Si votre site dispose déjà d’un service worker et que vous souhaitez utiliser un seul fichier, consultez plutôt Combiner plusieurs service workers.
Télécharger ou créer OneSignalSDKWorker.js
OneSignalSDKWorker.js avec la ligne de code suivante :onesignalsdkworker.js). Dans ce cas, remplacez simplement OneSignalSDKWorker.js dans ce guide par votre nom de fichier.Téléverser sur votre serveur web
OneSignalSDKWorker.js sur votre serveur de manière à ce qu’il soit accessible publiquement via HTTPS. Le fichier ne doit pas nécessiter d’authentification ou de connexion pour y accéder.Recommandé : Hébergez le fichier dans un sous-répertoire dédié qui ne servira jamais de pages, tel que /push/onesignal/. Cela évite les conflits avec d’autres service workers sur votre site (p. ex., un service worker de PWA ou AMP) et maintient la stabilité du chemin URL.- Exemple :
https://yoursite.com/push/onesignal/OneSignalSDKWorker.js
https://yoursite.com/OneSignalSDKWorker.js). Vous pouvez téléverser le fichier dans le répertoire racine, mais il peut entrer en conflit avec d’autres service workers nécessitant une portée racine. Par exemple, si vous utilisez une PWA, placez OneSignalSDKWorker.js dans un sous-répertoire.Vérifier que le fichier est accessible
https://yoursite.com/push/onesignal/OneSignalSDKWorker.js).Vous devriez voir la ligne importScripts de l’Étape 1 :
Configurer le chemin du SDK (sous-répertoire uniquement)
Configuration de site typique
- Dans le tableau de bord OneSignal, accédez à Paramètres > Push & In-App > Paramètres web.
- Sous Paramètres push avancés, activez Personnaliser les chemins et noms de fichiers du service worker.

| Champ | Description | Exemple |
|---|---|---|
| Path to service worker files | Répertoire où est hébergé OneSignalSDKWorker.js. | /push/onesignal/ |
| Service worker filename | Nom du fichier .js. | OneSignalSDKWorker.js |
| Service worker registration scope | Chemin URL contrôlé par le service worker. Doit être au niveau ou en dessous du répertoire où le fichier est hébergé. Utilisez un chemin qui ne sert jamais de pages orientées utilisateur. | /push/onesignal/ |
Configuration de code personnalisé
PassezserviceWorkerPath et serviceWorkerParam dans votre appel OneSignal.init() :| Paramètre | Description | Exemple |
|---|---|---|
serviceWorkerPath | Chemin relatif depuis la racine du site vers le fichier .js (sans barre oblique initiale). | "push/onesignal/OneSignalSDKWorker.js" |
serviceWorkerParam.scope | Chemin URL contrôlé par le service worker. Doit être au niveau ou en dessous du répertoire où le fichier est hébergé. Utilisez un chemin qui ne sert jamais de pages orientées utilisateur. | "/push/onesignal/" |
Vérifier les exigences du service worker
OneSignalSDKWorker.js doit satisfaire toutes les exigences suivantes. Si l’une d’elles n’est pas respectée, les notifications push ne fonctionneront pas.| Exigence | Détails |
|---|---|
| Accessible publiquement | Accédez à l’URL du fichier dans un navigateur et confirmez que vous voyez le code JavaScript. |
| Type de contenu correct | Le serveur doit retourner Content-Type: application/javascript; charset=utf-8. |
| Même origine | Le fichier doit être hébergé sur le même domaine que votre site. Les CDN et sous-domaines ne sont pas autorisés. Voir MDN : Enregistrement de votre worker. |
| HTTPS | Les service workers nécessitent un contexte sécurisé. localhost est la seule exception pendant le développement. |
Configuration du SDK Web
Combiner plusieurs service workers
Chaque fichier service worker sur votre site est enregistré à une portée — un chemin URL qui détermine quelles pages il contrôle. Un seul service worker peut être actif à une portée donnée. Si vous avez déjà un service worker (par exemple, une PWA ou un worker de mise en cache) et souhaitez qu’OneSignal partage le même fichier, vous pouvez les combiner. Pour combiner, ajoutez la ligneimportScripts de OneSignal à votre fichier service worker existant :
Guide de migration
Cette section est destinée aux clients OneSignal existants qui doivent modifier le chemin du fichier service worker, le nom de fichier ou la portée. Ne suivez pas ces étapes sauf si vous avez une raison spécifique de modifier votre configuration actuelle.Quand et comment migrer votre service worker
Quand et comment migrer votre service worker
- Le OneSignal service worker avec portée racine entre en conflit avec une Progressive Web App (PWA)
- Le service worker entre en conflit avec AMP ou un autre service worker de mise en cache
- Les politiques de sécurité interdisent le code de service worker tiers à portée racine
OneSignalSDKWorker.js contient uniquement :serviceWorkerParam comme décrit dans l’Étape 4 : Configurer le chemin du SDK. Aucune autre modification n’est nécessaire.Si votre fichier contient OneSignal + autre codeVotre service worker peut inclure des appels importScripts supplémentaires (p. ex., suite à la combinaison de plusieurs service workers). Si votre configuration actuelle fonctionne toujours, conservez-la telle quelle — séparer un service worker fusionné nécessite un déploiement en deux phases.Si vous devez les séparer :Ajouter un commentaire de rétention au fichier existant
importScripts de OneSignal dans votre service worker actuel, ajoutez :Créer un nouveau service worker dédié OneSignal
OneSignalSDKWorker.js dans un sous-répertoire (p. ex., /push/onesignal/) contenant uniquement :Mettre à jour la configuration OneSignal
OneSignal.init() comme décrit dans l’Étape 4 : Configurer le chemin du SDK.Attendre que les abonnés migrent
Nettoyage
importScripts de OneSignal du fichier service worker original.Créer le nouveau fichier au nouvel emplacement
OneSignalSDKWorker.js (ou votre nom de fichier choisi) dans le nouveau répertoire avec :Mettre à jour la configuration OneSignal
Attendre que les abonnés migrent
Nettoyage
Problèmes courants
Pourquoi mon service worker retourne-t-il un 404 ?
Le fichier n’est pas à l’URL attendue par le SDK. Accédez à l’URL complète du fichier dans votre navigateur pour confirmer qu’il est accessible. Si vous avez placé le fichier dans un sous-répertoire, vérifiez queserviceWorkerPath (code personnalisé) ou le paramètre de chemin du tableau de bord correspond à l’emplacement réel du fichier — incluant le répertoire et le nom de fichier.
Pourquoi les notifications ne s’affichent-elles plus après avoir déplacé le fichier service worker ?
Les abonnés existants référencent toujours l’ancienne URL du service worker. Le navigateur récupère l’URL enregistrée (mise en cache jusqu’à 24 heures) à chaque fois qu’un push arrive. Si l’ancienne URL retourne un 404, ces abonnés ne reçoivent pas les notifications. Continuez à héberger l’ancien fichier pendant au moins un an pendant que les abonnés migrent naturellement en revisitant votre site. Consultez le guide de migration et le guide Notifications push web non affichées.Puis-je héberger le service worker sur un CDN ou un sous-domaine ?
Non. Les navigateurs exigent que les service workers soient servis depuis la même origine que la page qui les enregistre. Le fichier doit être sur votre domaine principal — pas un CDN, un sous-domaine ou un domaine différent.Pourquoi ma PWA entre-t-elle en conflit avec le OneSignal service worker ?
Les deux sont probablement enregistrés à la portée racine (/) et un seul service worker peut être enregistré à une portée spécifique. Déplacez le OneSignal service worker vers une portée de sous-répertoire (p. ex., /push/onesignal/) pour que votre PWA conserve le contrôle de la portée racine, ou combinez les service workers comme décrit dans Combiner plusieurs service workers.
Puis-je renommer le fichier OneSignalSDKWorker.js ?
Oui. Si votre serveur nécessite une convention de nommage spécifique (p. ex., tout en minuscules), vous pouvez renommer le fichier en quelque chose commeonesignalsdkworker.js. Dans ce cas, mettez à jour le nom de fichier dans votre configuration OneSignal — soit le champ Service worker filename dans le tableau de bord, soit le paramètre serviceWorkerPath dans votre appel OneSignal.init(). Voir l’Étape 4 pour plus de détails.
Quel type de contenu mon serveur doit-il retourner pour le fichier service worker ?
Le serveur doit retournerContent-Type: application/javascript; charset=utf-8. Certaines configurations de serveur ou CDN peuvent retourner un type MIME incorrect, ce qui amène le navigateur à rejeter l’enregistrement du service worker.