在找解決方案時發現Cloudflare Turnstile ,免費又好介接,使用者體驗好,又更少誤判,且又提供相關的報表服務。
首先,你需要在 Cloudflare Turnstile 控制面板中註冊你的網站,並獲取一個站點密鑰(Site Key)和一個密鑰(Secret Key)。站點密鑰將用於前端集成,而密鑰將用於服務器端驗證。
在你的網頁中,你需要添加 Turnstile 的 JavaScript 庫,並使用你的站點密鑰初始化它。這通常涉及到在 HTML 表單中添加一個特定的元素,Cloudflare 的腳本將自動處理這個元素,為用戶展示一個挑戰(如果需要的話)。
<script src="https://challenges.cloudflare.com/turnstile/v0/api.js" async defer></script> <div class="turnstile" data-sitekey="你的站點密鑰"></div> const widgetId = turnstile.render(`#${containerId}`, { sitekey, language: 'en', action, execution, callback: function (token: string) { // console.log(`${widgetId}: Challenge Success ${token}`); setTurnstileToken(token); }, 'expired-callback': function () { // console.log('Expired Callback'); // refresh token setTurnstileToken(''); turnstile.reset(`#${containerId}`); // 當過期時,透過這方法重新刷新這個 token turnstile.execute(`#${containerId}`); }, });
當表單被提交時,Turnstile 將生成一個令牌(token),這個令牌需要被發送到你的服務器,以驗證用戶的請求是否合法。在 C# 中,你可以使用 HttpClient 類來向 Cloudflare 的驗證 API 發送請求,並傳入令牌和你的密鑰。
using System.Net.Http; using System.Threading.Tasks; using Newtonsoft.Json; public class TurnstileVerification { private const string VerifyUrl = "https://challenges.cloudflare.com/turnstile/v0/siteverify"; private readonly string _secretKey; public TurnstileVerification(string secretKey) { _secretKey = secretKey; } public async Task<bool> VerifyTokenAsync(string token) { using (var httpClient = new HttpClient()) { var response = await httpClient.PostAsync(VerifyUrl, new FormUrlEncodedContent(new[] { new KeyValuePair<string, string>("secret", _secretKey), new KeyValuePair<string, string>("response", token), })); if (response.IsSuccessStatusCode) { var responseContent = await response.Content.ReadAsStringAsync(); var verificationResponse = JsonConvert.DeserializeObject<TurnstileVerificationResponse>(responseContent); return verificationResponse.Success; } } return false; } } public class TurnstileVerificationResponse { [JsonProperty("success")] public bool Success { get; set; } // 根據需要添加更多屬性 }
根據 VerifyTokenAsync 方法的返回值,你可以決定是否處理用戶的請求。如果驗證成功(返回 true),則可以繼續處理請求;如果失敗,則可能需要拒絕請求或要求用戶重試。
Cloudflare turnstile同時上線,阻止20-30% 以上的機器人重置密碼、登入、建立帳號、機械人惡意測試銀行信用卡的請求。