WordPress-integrointi

Suojaa WordPress-lomakkeesi SilentShieldillä. Toimii Contact Form 7:n, WPFormsin, Gravity Formsin ja minkä tahansa mukautettujen lomakkeiden kanssa.

1. Lisää skripti

Lisää tämä koodi teemasi functions.php-tiedostoon tai käytä lisäosaa kuten 'Insert Headers and Footers':

functions.phpphp
// functions.php
function silentshield_enqueue() {
    wp_enqueue_script(
        'silentshield',
        'https://api.silentshield.io/client.js?key=YOUR_API_KEY',
        array(),
        null,
        true
    );
    wp_add_inline_script('silentshield', "
        document.addEventListener('DOMContentLoaded', function() {
            SilentShield.init({ apiKey: 'YOUR_API_KEY' });
        });
    ");
}
add_action('wp_enqueue_scripts', 'silentshield_enqueue');

2. Palvelinpuolen vahvistus

Lisää nonce-vahvistus lomakekäsittelijääsi. Mukautetuissa lomakkeissa lisää tämä käsittelyfunktioosi:

PHPphp
function verify_silentshield_nonce() {
    $nonce = sanitize_text_field($_POST['ss_nonce'] ?? '');
    if (empty($nonce)) {
        wp_die('Missing verification', 'Error', array('response' => 422));
    }

    $response = wp_remote_post('https://api.silentshield.io/api/v1/captcha/verify-nonce', array(
        'headers' => array(
            'Content-Type' => 'application/json',
            'X-Api-Key' => SILENTSHIELD_API_KEY,
        ),
        'body' => wp_json_encode(array('nonce' => $nonce)),
        'timeout' => 5,
    ));

    if (is_wp_error($response)) {
        return; // fail open
    }

    $body = json_decode(wp_remote_retrieve_body($response), true);
    if (($body['verdict'] ?? '') === 'bot') {
        wp_die('Bot detected', 'Forbidden', array('response' => 403));
    }
}

Contact Form 7

Widget tunnistaa Contact Form 7 -lomakkeet automaattisesti. Lisämäärityksiä ei tarvita — lisää vain skripti, ja widget suojaa kaikki sivun CF7-lomakkeet.

WPForms / Gravity Forms

SilentShield tunnistaa automaattisesti WPFormsin, Gravity Formsin ja muiden suosittujen lomake-lisäosien lomakkeet. Widget lisää noncen kaikkiin sivulta löytämiinsä lomakkeisiin.

API-avaimen tallennus

Lisää API-avaimesi wp-config.php-tiedostoon turvallisuuden takaamiseksi:

wp-config.phpphp
// wp-config.php
define('SILENTSHIELD_API_KEY', 'your-api-key-here');