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.

Si vous utilisez notre plugin WordPress, le service worker est ajouté automatiquement. Ignorez ce guide et revenez à la configuration WordPress.
Configuration du service worker
Ces étapes créent un fichierOneSignalSDKWorker.js dédié pour les notifications push OneSignal. Il s’agit de la configuration recommandée. 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.
Étape 1 : Télécharger ou créer OneSignalSDKWorker.js
Téléchargez le fichier depuis le tableau de bord OneSignal lors de la configuration du Web SDK ou depuis GitHub. Vous pouvez également créer un fichier nomméOneSignalSDKWorker.js avec la ligne de code suivante :
Vous pouvez renommer le fichier si nécessaire (p. ex.,
onesignalsdkworker.js). Dans ce cas, remplacez simplement OneSignalSDKWorker.js dans ce guide par votre nom de fichier.Étape 2 : Téléverser sur votre serveur web
PlacezOneSignalSDKWorker.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.
Étape 3 : Vérifier que le fichier est accessible
Accédez à l’URL du fichier dans votre navigateur (p. ex.,https://yoursite.com/push/onesignal/OneSignalSDKWorker.js).
Vous devriez voir la ligne importScripts de l’Étape 1 :

Étape 4 : Configurer le chemin du SDK (sous-répertoire uniquement)
Si vous avez placé le fichier à la racine de votre site, aucune configuration supplémentaire n’est nécessaire — passez à l’Étape 5. Si vous avez placé le fichier dans un sous-répertoire, indiquez au SDK où le trouver :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() :
HTML
| 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/" |
Étape 5 : Vérifier les exigences du service worker
Le fichierOneSignalSDKWorker.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. |
La configuration du service worker est terminée. Revenez au guide de configuration du Web SDK pour les prochaines étapes.
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
Raisons de migrer :Mettez à jour la portée en utilisant le tableau de bord ou Option 2 : Changer le nom de fichier ou l’emplacement du fichierChanger le nom de fichier ou le répertoire est plus complexe car les navigateurs récupèrent le service worker depuis l’URL où il a été initialement enregistré. Les abonnés qui n’ont pas revisité votre site référencent toujours l’ancienne URL.Si votre fichier contient uniquement du code OneSignalSi votre fichier contient OneSignal + autre codeSuivez les étapes de l’Option 1 : Changer uniquement la portée ci-dessus. Le processus est identique.
- 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
Au-dessus de la ligne Définissez la date à au moins un an dans le futur.
importScripts de OneSignal dans votre service worker actuel, ajoutez :Créer un nouveau service worker dédié OneSignal
Créez
OneSignalSDKWorker.js dans un sous-répertoire (p. ex., /push/onesignal/) contenant uniquement :Mettre à jour la configuration OneSignal
Définissez le nouveau chemin et la nouvelle portée en utilisant le tableau de bord ou
OneSignal.init() comme décrit dans l’Étape 4 : Configurer le chemin du SDK.Attendre que les abonnés migrent
Les nouveaux visiteurs et ceux qui reviennent s’enregistrent automatiquement avec le nouveau service worker. Attendez au moins un an pour que la majorité des abonnés existants revisitent votre site.
Nettoyage
Supprimez les utilisateurs inactifs plus anciens que votre période de rétention choisie, puis supprimez la ligne
importScripts de OneSignal du fichier service worker original.Créer le nouveau fichier au nouvel emplacement
Placez
OneSignalSDKWorker.js (ou votre nom de fichier choisi) dans le nouveau répertoire avec :Mettre à jour la configuration OneSignal
Définissez le nouveau chemin, nom de fichier et portée comme décrit dans l’Étape 4 : Configurer le chemin du SDK.
Attendre que les abonnés migrent
Les nouveaux visiteurs et ceux qui reviennent s’enregistrent avec le nouveau fichier automatiquement. Attendez au moins un an.
Nettoyage
Supprimez les utilisateurs inactifs plus anciens que votre période de rétention, puis supprimez l’ancien fichier.
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 comme onesignalsdkworker.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 retourner Content-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.