Protect your login pages
Last reviewed: 8 months ago
This tutorial will guide you through integrating Cloudflare Turnstile to protect your login page. Learn how to implement the Turnstile widget on the client side and verify the Turnstile token via the siteverify API on the server side.
- You must have a Cloudflare account.
- You must have a web application with a login or signup page.
- You must have basic knowledge of HTML and your server-side language of choice, such as Node.js or Python.
- Log in to the Cloudflare dashboard ↗ and select your account.
- Go to Turnstile and create a new Turnstile widget.
- Copy the sitekey and the secret key to use in the next step.
- Add the Turnstile widget to your login form.
- Replace
YOUR-SITE-KEY
with the sitekey from Cloudflare.
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Login Page</title> <script src="https://challenges.cloudflare.com/turnstile/v0/api.js" async defer></script></head><body> <form id="login-form" action="/login" method="POST"> <input type="text" name="username" placeholder="Username" required> <input type="password" name="password" placeholder="Password" required>
<!-- Turnstile widget --> <div class="cf-turnstile" data-sitekey="YOUR-SITE-KEY"></div>
<button type="submit">Log in</button> </form></body></html>
You will need to verify the Turnstile token sent from the client side. Below is an example in Node.js.
const express = require('express');const axios = require('axios');const bodyParser = require('body-parser');const app = express();
app.use(bodyParser.urlencoded({ extended: true }));
app.post('/login', async (req, res) => { const turnstileToken = req.body['cf-turnstile-response']; const secretKey = 'your-secret-key';
try { const response = await axios.post('https://challenges.cloudflare.com/turnstile/v0/siteverify', null, { params: { secret: secretKey, response: turnstileToken } });
if (response.data.success) { // Token is valid, proceed with login const username = req.body.username; const password = req.body.password; // Your login logic here res.send('Login successful'); } else { res.status(400).send('Turnstile verification failed'); } } catch (error) { res.status(500).send('Error verifying Turnstile token'); }});
app.listen(3000, () => { console.log('Server is running on port 3000');});
It is crucial to handle the verification of the Turnstile token correctly. This section covers some key points to keep in mind.
- Ensure that you verify the Turnstile token after the user has put in their credentials and selected log in to your website or application.
- If you verify the token before the user inputs their credentials, a malicious visitor could bypass the protection by reentering the login credentials.
- When the user submits the login form, send both the login credentials and the Turnstile token to your server.
- On the server side, verify the Turnstile token first.
- Based on the verification response, decide whether to proceed with checking the login credentials.