---
title: Prévention de la fraude — SDK Web
---
# SDK Web de prévention de la fraude
Le SDK Web de prévention de la fraude s’exécute sur **votre page** — une page de
destination, un écran d’inscription ou de connexion, ou toute ressource protégée. Il demande
un verdict pour la visite en cours et le restitue à votre code, afin que vous puissiez
décider quoi faire du trafic — l’enregistrer, le signaler ou demander au visiteur une
vérification supplémentaire.
## Démarrage rapide
```html
```
`BotSignal.init()` renvoie également une `Promise`, vous pouvez donc aussi
`await` le résultat au lieu d’utiliser `onVerdict` — les deux reçoivent le même objet
verdict.
```js
const verdict = await BotSignal.init({ appKey: 'YOUR_APP_KEY' });
```
## Options
| Option | Type | Défaut | Description |
| --- | --- | --- | --- |
| `appKey` | string | — | Votre clé d’application de prévention de la fraude (obligatoire). |
| `domain` | string | défaut du service | Point de terminaison du service de verdict. À laisser non défini, sauf si un domaine dédié vous a été fourni. |
| `escalate` | boolean | `false` | Autorise la prévention de la fraude à demander au visiteur **une vérification supplémentaire** lorsqu’une visite paraît à haut risque. Voir [Escalade](#escalade). |
| `collectWindowMs` | number | `1200` | Durée (ms) pendant laquelle le SDK observe la visite avant de demander un verdict. Des fenêtres plus longues produisent un verdict plus fiable au prix d’un léger délai. |
| `onVerdict` | `(v) => void` | — | Appelé une fois avec le verdict final. Le principal point d’intégration. |
| `onError` | `(err) => void` | — | Appelé en cas de problème. Le SDK ne lève jamais d’exception dans votre page. |
| `onEscalate` | `(displayType) => void` | — | Appelé lorsqu’une vérification supplémentaire est affichée (uniquement quand `escalate: true`). |
| `onEscalateDone` | `(passed) => void` | — | Appelé après la fin de la vérification supplémentaire ; `passed` vaut `true` si le visiteur l’a réussie. |
::: tip Scénarios de source de trafic
Si un tiers vous fournit des visiteurs et que les deux parties doivent se rapprocher sur
une conclusion par clic, le SDK peut aussi lire un jeton de clic depuis l’URL de la page.
Cela est propre aux flux de trafic payant — voir le guide [Fraude publicitaire](./scenarios/ad-fraud).
:::
## Exploiter le verdict
`onVerdict` reçoit un objet `BotVerdict`. Les deux champs que vous utiliserez le plus :
- **`verdict.is_bot`** — `true` lorsque la visite est jugée automatisée/invalide.
- **`verdict.action`** — ce que nous recommandons de faire : `record_only`, `challenge` ou
`flag`.
```js
BotSignal.init({
appKey: 'YOUR_APP_KEY',
onVerdict: function (verdict) {
switch (verdict.action) {
case 'record_only':
// normal-looking traffic — proceed, just log the verdict
break;
case 'flag':
// suspicious — keep serving the page but mark this visit as low quality
markLowQuality(verdict);
break;
case 'challenge':
// high risk — handled by escalation if enabled (see below)
break;
}
},
});
```
Consultez la liste complète des champs et le traitement recommandé dans la
[Référence du verdict](./verdict-reference).
## Escalade
Lorsqu’une visite paraît à haut risque, la prévention de la fraude peut demander au visiteur
de réaliser **une vérification supplémentaire** avant que vous ne le traitiez comme un
utilisateur réel. C’est une fonctionnalité optionnelle.
Activez-la avec `escalate: true` :
```js
BotSignal.init({
appKey: 'YOUR_APP_KEY',
escalate: true,
onEscalate: function (displayType) {
// an extra verification is being shown to the visitor
},
onEscalateDone: function (passed) {
if (passed) {
// visitor cleared the extra check — treat as human
} else {
// not cleared — keep the original verdict's recommendation
}
},
onVerdict: function (verdict) {
// if the visitor cleared escalation, verdict.is_bot is updated to false
},
});
```
Remarques :
- L’escalade ne se déclenche que lorsque l’`action` du verdict est `challenge`. Pour toutes
les autres visites, rien n’est affiché et l’expérience du visiteur reste intacte.
- Si le visiteur réussit la vérification supplémentaire, le verdict transmis à `onVerdict`
en tient compte (traité comme humain).
- L’escalade **échoue en mode ouvert** : si la vérification supplémentaire ne peut pas être
chargée ou affichée, le SDK conserve le verdict initial plutôt que de bloquer votre page.
::: info
La prévention de la fraude ne décide jamais *à votre place*. Même en cas de
`challenge`/`flag`, votre code garde la main sur la décision de laisser la visite se
poursuivre — le SDK ne fait que présenter le verdict et, en option, exécuter la
vérification supplémentaire.
:::
## Résilience
Si le service de verdict est injoignable ou qu’une erreur se produit, le SDK renvoie un
verdict **dégradé** (`degraded: true`) au lieu de faire échouer votre page. Un verdict
dégradé est conservateur (`is_bot: false`, `action: record_only`), de sorte qu’il ne bloque
jamais d’utilisateurs réels. Vérifiez `verdict.degraded` si vous souhaitez traiter ces
visites de manière particulière.
## Étapes suivantes
- [Référence du verdict](./verdict-reference) — chaque champ et comment agir dessus
- [API de données](./data-api) — récupérez et rapprochez les verdicts côté serveur