Annoter les évaluations

Cette page explique comment envoyer des commentaires sur la précision des évaluations créées par reCAPTCHA. Grâce à ces informations, reCAPTCHA peut ajuster le modèle spécifique à votre site et l'améliorer au fil du temps.

Quand annoter les évaluations

reCAPTCHA fournit un score lors de la création d'une évaluation qui vous aide à comprendre le niveau de risque des interactions utilisateur. Plus tard, lorsque votre site aura plus d'informations sur les interactions des utilisateurs pour déterminer si l'interaction était légitime ou frauduleuse, vous pourrez confirmer ou corriger l'évaluation de reCAPTCHA. Pour ce faire, renvoyez à Google les ID d'évaluation reCAPTCHA identifiés comme LEGITIMATE ou FRAUDULENT. Le fait de confirmer ou de corriger l'évaluation de reCAPTCHA améliore les performances de reCAPTCHA pour votre site.

Pour améliorer les performances de reCAPTCHA, vous pouvez confirmer les annotations de vrais positifs et de vrais négatifs en plus des annotations d'erreurs d'évaluation potentielles. Par exemple, dans le cas d'un utilisateur qui s'est authentifié à l'aide d'une méthode d'authentification à deux facteurs et qui a reçu un score reCAPTCHA élevé, vous pouvez annoter l'évaluation comme LEGITIMATE. Si le score reCAPTCHA est faible et que votre site détermine que l'interaction est frauduleuse ou abusive, vous pouvez annoter l'évaluation comme FRAUDULENT.

La liste suivante contient des informations supplémentaires sur des exemples d'interactions utilisateur qui indiquent si une interaction est légitime ou frauduleuse :

  • Les rejets de débit de carte de crédit ou d'autres preuves concrètes de fraude indiquent qu'une transaction financière antérieure était frauduleuse.
  • Un nouveau compte qui envoie des messages signalés comme spam par d'autres utilisateurs peut indiquer que la création du compte est frauduleuse.
  • Une demande d'assistance envoyée si un utilisateur rencontre des difficultés pour se connecter à son compte peut indiquer que la tentative de connexion est légitime.
  • Un achat ou une réservation sur un site qui utilise reCAPTCHA pour se protéger contre le scraping peut indiquer que l'utilisateur est légitime.

Avant de commencer

Récupérer l'ID d'évaluation

Pour annoter une évaluation, récupérez l'ID d'évaluation unique comme suit:

  • Pour les intégrations Web et mobiles, vous pouvez récupérer l'ID d'évaluation unique à partir de la réponse d'évaluation.

    Après avoir créé une évaluation, vous recevez une réponse JSON comme illustré dans l'exemple suivant.

    Récupérez l'ID d'évaluation unique à partir du champ name de la réponse JSON.

    {
    'tokenProperties': {
      'valid': True,
      'hostname': 'www.google.com',
      'action': 'homepage',
      'createTime': u'2019-03-28T12:24:17.894Z'
    },
    'riskAnalysis': {
      'score': 0.1,
      'reasons': ['AUTOMATION']
    },
    'event': {
      'token': 'RESPONSE_TOKEN',
      'siteKey': 'KEY_ID'
    },
    'name': 'ASSESSMENT_ID'
    }
  • Pour les intégrations WAF, vous pouvez récupérer l'ID d'évaluation unique à partir du jeton reCAPTCHA. L'ID d'évaluation unique est la chaîne alphanumérique unique de 16 caractères qui apparaît à la fin du jeton reCAPTCHA après :U=. Par exemple, si le jeton reCAPTCHA est .................U=6ZZZZe73fZZZZZZ0, l'ID d'évaluation est 6ZZZZe73fZZZZZZ0.

Annoter une évaluation

  1. Déterminez les informations et les libellés à ajouter dans le corps de la requête JSON en fonction de votre cas d'utilisation.

    Le tableau suivant liste les libellés et les valeurs que vous pouvez utiliser pour annoter les événements:

    Libellé Description Exemple de requête
    reasons Facultatif. Un libellé pour étayer vos évaluations.

    Fournissez des informations sur l'événement en temps réel dans l'étiquette reasons quelques secondes ou minutes après l'événement, car elles influencent la détection en temps réel.

    Pour obtenir la liste des valeurs possibles, consultez la section Valeurs de reasons.

    Exemple: Pour détecter les piratages de compte, indiquez si le mot de passe saisi était correct à l'aide des valeurs CORRECT_PASSWORD ou INCORRECT_PASSWORD. Si vous avez déployé votre propre MFA, vous pouvez ajouter les valeurs suivantes: INITIATED_TWO_FACTOR, PASSED_TWO_FACTOR ou FAILED_TWO_FACTOR.

          {
          "reasons": ["INCORRECT_PASSWORD"]
          }
        
    annotation Facultatif. Libellé indiquant la légitimité des évaluations.

    Fournissez des informations sur les événements de connexion et d'enregistrement pour valider ou corriger vos évaluations des risques dans le libellé annotation.

    Valeurs possibles: LEGITIMATE ou FRAUDULENT.

    Vous pouvez envoyer ces informations à tout moment ou dans le cadre d'une job par lot. Toutefois, nous vous recommandons d'envoyer ces informations quelques secondes ou minutes après l'événement, car elles ont une incidence sur la détection en temps réel.

          {
           "annotation": "LEGITIMATE"
          }
    
      

  2. Annotez une évaluation à l'aide de la méthode projects.assessments.annotate avec gcloud CLI ou une clé API.

    CLI gcloud

    Avant d'utiliser les données de requête ci-dessous, effectuez les remplacements suivants :

    • ASSESSMENT_ID: valeur du champ name renvoyée par l'appel projects.assessments.create.
    • ANNOTATION_LABEL: libellé indiquant si l'évaluation est légitime ou frauduleuse. Les valeurs possibles sont LEGITIMATE ou FRAUDULENT.
    • ANNOTATION_REASON: décrit le contexte de l'annotation choisie pour cette évaluation. Pour en savoir plus sur les valeurs possibles, consultez la section Pourquoi annoter une évaluation.

    Méthode HTTP et URL :

    POST https://recaptchaenterprise.googleapis.com/v1/ASSESSMENT_ID:annotate

    Corps JSON de la requête :

    {
    "annotation": "ANNOTATION_LABEL"
    "reasons": "ANNOTATION_REASON"
    }
    

    Pour envoyer votre requête, choisissez l'une des options suivantes :

    curl

    Enregistrez le corps de la requête dans un fichier nommé request.json, puis exécutez la commande suivante :

    curl -X POST \
    -H "Authorization: Bearer $(gcloud auth print-access-token)" \
    -H "Content-Type: application/json; charset=utf-8" \
    -d @request.json \
    "https://recaptchaenterprise.googleapis.com/v1/ASSESSMENT_ID:annotate"

    PowerShell

    Enregistrez le corps de la requête dans un fichier nommé request.json, puis exécutez la commande suivante :

    $cred = gcloud auth print-access-token
    $headers = @{ "Authorization" = "Bearer $cred" }

    Invoke-WebRequest `
    -Method POST `
    -Headers $headers `
    -ContentType: "application/json; charset=utf-8" `
    -InFile request.json `
    -Uri "https://recaptchaenterprise.googleapis.com/v1/ASSESSMENT_ID:annotate" | Select-Object -Expand Content

    Vous devriez recevoir un code d'état indiquant le succès de l'opération (2xx), ainsi qu'une réponse vide.

    Clé API

    Avant d'utiliser les données de requête ci-dessous, effectuez les remplacements suivants :

    • ASSESSMENT_ID : valeur du champ name renvoyée par l'appel projects.assessments.create
    • ANNOTATION_LABEL: libellé indiquant si l'évaluation est légitime ou frauduleuse. Les valeurs possibles sont LEGITIMATE ou FRAUDULENT.
    • ANNOTATION_REASON: décrit le contexte de l'annotation choisie pour cette évaluation. Pour en savoir plus sur les valeurs possibles, consultez la section Pourquoi annoter une évaluation.

    Méthode HTTP et URL :

    POST https://recaptchaenterprise.googleapis.com/v1/projects/PROJECT_ID/assessments/ASSESSMENT_ID:annotate?key=API_KEY

    Corps JSON de la requête :

    {
    "annotation": "ANNOTATION_LABEL"
    "reasons": "ANNOTATION_REASON"
    }
    

    Pour envoyer votre requête, choisissez l'une des options suivantes :

    curl

    Enregistrez le corps de la requête dans un fichier nommé request.json, puis exécutez la commande suivante :

    curl -X POST \
    -H "Content-Type: application/json; charset=utf-8" \
    -d @request.json \
    "https://recaptchaenterprise.googleapis.com/v1/projects/PROJECT_ID/assessments/ASSESSMENT_ID:annotate?key=API_KEY"

    PowerShell

    Enregistrez le corps de la requête dans un fichier nommé request.json, puis exécutez la commande suivante :

    $headers = @{  }

    Invoke-WebRequest `
    -Method POST `
    -Headers $headers `
    -ContentType: "application/json; charset=utf-8" `
    -InFile request.json `
    -Uri "https://recaptchaenterprise.googleapis.com/v1/projects/PROJECT_ID/assessments/ASSESSMENT_ID:annotate?key=API_KEY" | Select-Object -Expand Content

    Vous devriez recevoir un code d'état indiquant le succès de l'opération (2xx), ainsi qu'une réponse vide.

Étape suivante