AI-generated Key Takeaways
- 
          This page provides instructions on how to integrate and customize the reCAPTCHA v2 widget to protect your website from bots. 
- 
          You can display the reCAPTCHA widget either automatically using a simple HTML tag or explicitly with a JavaScript callback for more control. 
- 
          Customization options include setting the theme, size, and language of the widget, as well as handling user responses and errors. 
- 
          The JavaScript API offers methods to render, reset, and retrieve responses from the widget for advanced integration. 
This page explains how to display and customize the reCAPTCHA v2 widget on your webpage.
To display the widget, you can either:
See Configurations to learn how to customize your widget. For example, you may want to specify the language or theme for the widget.
See Verifying the user's response to check if the user successfully solved the CAPTCHA.
Automatically render the reCAPTCHA widget
The easiest method for rendering the reCAPTCHA widget on your page is to include
the necessary JavaScript resource and a g-recaptcha tag. The g-recaptcha tag
is a DIV element with class name g-recaptcha and your site key in the
data-sitekey attribute:
<html>
  <head>
    <title>reCAPTCHA demo: Simple page</title>
    <script src="https://www.google.com/recaptcha/api.js" async defer></script>
  </head>
  <body>
    <form action="?" method="POST">
      <div class="g-recaptcha" data-sitekey="your_site_key"></div>
      <br/>
      <input type="submit" value="Submit">
    </form>
  </body>
</html>
The script must be loaded using the HTTPS protocol and can be included from any point on the page without restriction.
Explicitly render the reCAPTCHA widget
Deferring the render can be achieved by specifying your onload callback function and adding parameters to the JavaScript resource.
- Specify your - onloadcallback function. This function will get called when all the dependencies have loaded.- <script type="text/javascript"> var onloadCallback = function() { alert("grecaptcha is ready!"); }; </script>
- Insert the JavaScript resource, setting the - onloadparameter to the name of your onload callback function and the- renderparameter to- explicit.- <script src="https://www.google.com/recaptcha/api.js?onload=onloadCallback&render=explicit" async defer> </script>- When your callback is executed, you can call the - grecaptcha.rendermethod from the JavaScript API.
Configuration
JavaScript resource (api.js) parameters
| Parameter | Value | Description | 
|---|---|---|
| onload | Optional. The name of your callback function to be executed once all the dependencies have loaded. | |
| render | explicit onload | Optional. Whether to render the widget explicitly. Defaults to onload, which will render the widget in the first g-recaptchatag it finds. | 
| hl | See language codes | Optional. Forces the widget to render in a specific language. Auto-detects the user's language if unspecified. | 
g-recaptcha tag attributes and grecaptcha.render parameters
| g-recaptcha tag attribute | grecaptcha.render parameter | Value | Default | Description | 
|---|---|---|---|---|
| data-sitekey | sitekey | Your sitekey. | ||
| data-theme | theme | dark light | light | Optional. The color theme of the widget. | 
| data-size | size | compact normal | normal | Optional. The size of the widget. | 
| data-tabindex | tabindex | 0 | Optional. The tabindex of the widget and challenge. If other elements in your page use tabindex, it should be set to make user navigation easier. | |
| data-callback | callback | Optional. The name of your callback function, executed when the user submits a successful response. The g-recaptcha-responsetoken is passed to your callback. | ||
| data-expired-callback | expired-callback | Optional. The name of your callback function, executed when the reCAPTCHA response expires and the user needs to re-verify. | ||
| data-error-callback | error-callback | Optional. The name of your callback function, executed when reCAPTCHA encounters an error (usually network connectivity) and cannot continue until connectivity is restored. If you specify a function here, you are responsible for informing the user that they should retry. | 
JavaScript API
| Method | Description | 
|---|---|
| grecaptcha.render(container, parameters | Renders the container as a reCAPTCHA widget and returns the ID of the newly created widget. container The HTML element to render the reCAPTCHA widget. Specify either the ID of the container (string) or the DOM element itself. parameters An object containing parameters as key=value pairs, for example, {"sitekey": "your_site_key", "theme": "light"}. See grecaptcha.render parameters. | 
| grecaptcha.reset( | Resets the reCAPTCHA widget. opt_widget_id Optional widget ID, defaults to the first widget created if unspecified. | 
| grecaptcha.getResponse( | Gets the response for the reCAPTCHA widget. opt_widget_id Optional widget ID, defaults to the first widget created if unspecified. | 
Examples
Explicit rendering after an onload callback
<html>
  <head>
    <title>reCAPTCHA demo: Explicit render after an onload callback</title>
    <script type="text/javascript">
      var onloadCallback = function() {
        grecaptcha.render('html_element', {
          'sitekey' : 'your_site_key'
        });
      };
    </script>
  </head>
  <body>
    <form action="?" method="POST">
      <div id="html_element"></div>
      <br>
      <input type="submit" value="Submit">
    </form>
    <script src="https://www.google.com/recaptcha/api.js?onload=onloadCallback&render=explicit"
        async defer>
    </script>
  </body>
</html>
Explicit rendering for multiple widgets
<html>
  <head>
    <title>reCAPTCHA demo: Explicit render for multiple widgets</title>
    <script type="text/javascript">
      var verifyCallback = function(response) {
        alert(response);
      };
      var widgetId1;
      var widgetId2;
      var onloadCallback = function() {
        // Renders the HTML element with id 'example1' as a reCAPTCHA widget.
        // The id of the reCAPTCHA widget is assigned to 'widgetId1'.
        widgetId1 = grecaptcha.render('example1', {
          'sitekey' : 'your_site_key',
          'theme' : 'light'
        });
        widgetId2 = grecaptcha.render(document.getElementById('example2'), {
          'sitekey' : 'your_site_key'
        });
        grecaptcha.render('example3', {
          'sitekey' : 'your_site_key',
          'callback' : verifyCallback,
          'theme' : 'dark'
        });
      };
    </script>
  </head>
  <body>
    <!-- The g-recaptcha-response string displays in an alert message upon submit. -->
    <form action="javascript:alert(grecaptcha.getResponse(widgetId1));">
      <div id="example1"></div>
      <br>
      <input type="submit" value="getResponse">
    </form>
    <br>
    <!-- Resets reCAPTCHA widgetId2 upon submit. -->
    <form action="javascript:grecaptcha.reset(widgetId2);">
      <div id="example2"></div>
      <br>
      <input type="submit" value="reset">
    </form>
    <br>
    <!-- POSTs back to the page's URL upon submit with a g-recaptcha-response POST parameter. -->
    <form action="?" method="POST">
      <div id="example3"></div>
      <br>
      <input type="submit" value="Submit">
    </form>
    <script src="https://www.google.com/recaptcha/api.js?onload=onloadCallback&render=explicit"
        async defer>
    </script>
  </body>
</html>
