
在找解決方案時發現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% 以上的機器人重置密碼、登入、建立帳號、機械人惡意測試銀行信用卡的請求。
 
    
    