CAPSOLVER
ブログ
CloudflareチャレンジをNode.JSで解決する方法

CloudflareチャレンジをNode.jsで解決する方法

Logo of CapSolver

Sora Fujimoto

AI Solutions Architect

03-Dec-2025

はじめに

Node.jsの自動化スクリプトが常にクラウドフレアによってブロックされていますか?あなたは一人ではありません。クラウドフレアの強力なセキュリティメジャー、例えばJavaScriptチャレンジや「I'm Under Attack」モードは、ボットを停止するのに効果的ですが、正当なウェブスクリーピングやデータ抽出タスクも停止する可能性があります。これらのセキュリティチェックは、自動化されたスクリプトがよく失敗するバックグラウンドテストを実行して、訪問者を検証します。

このガイドでは、この障害を乗り越える方法を紹介します。Node.jsと**CapSolver**サービスを使用して、クラウドフレアチャレンジを効率的に解決し、シームレスなアクセスに必要なcf_clearanceトークンを取得する、明確なステップバイステップのプロセスを説明します。

⚙️ 前提条件

開始する前に、以下の準備が整っていることを確認してください:

  • 動作するプロキシ: これはクラウドフレアチャレンジを解決するためには不可欠です。ISPまたは住宅プロキシを使用することを強くお勧めします。そのIPアドレスは、ブロックされる可能性が低いです。
  • Node.jsがインストールされていること: システムにNode.jsがインストールされていることを確認してください。
  • CapSolver APIキー: APIキーを取得するには、CapSolverアカウントが必要です。CapSolverは、さまざまなCAPTCHAおよびボットチャレンジを処理するためのAIベースのサービスです。

🤖 ステップ1: 必要なNode.jsパッケージをインストールする

まず、HTTPリクエストを行うためにaxiosライブラリをインストールする必要があります。ターミナルを開き、次のコマンドを実行してください:

bash Copy
npm install axios

👨‍💻 ステップ2: Node.jsコードを書くことでクラウドフレアチャレンジを解決する

Node.jsとCapSolver APIを使用してクラウドフレアチャレンジを解決し、cf_clearanceトークンを取得するためのサンプルコードを以下に示します。このコードは、AntiCloudflareTaskを作成し、解決を待って結果を取得する方法を示しています。

更新されたNode.jsコード

このコードは、カップソルバー公式ドキュメントの最新の実践を組み込み、よりクリーンな構造と必要なコメントを備えています。

javascript Copy
const axios = require('axios');

// -------------------PLEASE MODIFY THESE VALUES-------------------
// http://username:password@ip:portの形式でプロキシの詳細を入力してください
const PROXY = 'http://username:password@ip:port'; 
// カップソルバーのダッシュボードから取得したAPIキー
const CAPSOLVER_API_KEY = 'YourAPIKEY';
// クラウドフレアチャレンジを解決したいターゲットウェブサイトのURL
const PAGE_URL = 'https://www.yourwebsite.com';
// ----------------------------------------------------------------


/**
 * カップソルバーAPIを使用してクラウドフレアチャレンジを解決するタスクを作成します。
 * @param {string} websiteURL - ターゲットウェブサイトのURL
 * @param {string} proxy - 使用するプロキシ
 * @returns {Promise<string|null>} - タスクID、または作成に失敗した場合null
 */
async function createCloudflareTask(websiteURL, proxy) {
    console.log('クラウドフレアタスクを作成しています...');
    try {
        const response = await axios.post('https://api.capsolver.com/createTask', {
            clientKey: CAPSOLVER_API_KEY,
            task: {
                type: 'AntiCloudflareTask',
                websiteURL: websiteURL,
                proxy: proxy
            }
        });
        if (response.data.errorId > 0) {
            console.error(`タスクの作成に失敗しました: ${response.data.errorDescription}`);
            return null;
        }
        console.log(`タスクが正常に作成されました。タスクID: ${response.data.taskId}`);
        return response.data.taskId;
    } catch (error) {
        console.error(`タスクの作成中にエラーが発生しました: ${error}`);
        return null;
    }
}

/**
 * タスク結果をポーリングします。
 * @param {string} taskId - カップソルバーから返されたタスクID
 * @returns {Promise<object|null>} - 解決オブジェクト、または失敗した場合null
 */
async function getTaskResult(taskId) {
    console.log(`タスクID ${taskId}の結果を取得しています...`);
    let solution = null;

    while (!solution) {
        await new Promise(resolve => setTimeout(resolve, 3000)); // 3秒待機

        try {
            const response = await axios.post('https://api.capsolver.com/getTaskResult', {
                clientKey: CAPSOLVER_API_KEY,
                taskId: taskId
            });

            if (response.data.errorId > 0) {
                console.error(`結果の取得に失敗しました: ${response.data.errorDescription}`);
                return null;
            }

            if (response.data.status === 'ready') {
                console.log('解決が正常に取得されました!');
                solution = response.data.solution;
            } else if (response.data.status === 'processing') {
                console.log('タスクはまだ処理中です、お待ちください...');
            } else if (response.data.status === 'failed') {
                console.error(`タスクの処理に失敗しました: ${response.data.errorDescription}`);
                return null;
            }
        } catch (error) {
            console.error(`結果の取得中にエラーが発生しました: ${error}`);
            return null;
        }
    }
    return solution;
}

/**
 * 全てのプロセスを実行するメイン関数
 */
async function main() {
    console.log('クラウドフレアチャレンジを解決し始めます...');
    
    const taskId = await createCloudflareTask(PAGE_URL, PROXY);
    if (!taskId) {
        console.log('タスクの作成に失敗しました、終了します。');
        return;
    }

    const solution = await getTaskResult(taskId);
    if (!solution) {
        console.log('解決の取得に失敗しました、終了します。');
        return;
    }

    console.log('解決の詳細を取得しました:');
    console.log(solution);

    // 今後、取得したクッキーとUser-Agentを使用してターゲットウェブサイトにアクセスできます。
    // 解決オブジェクトには'URL'、'status'、'headers'、'cookies'、'User-Agent'が含まれます。
    
    // 例: 取得したクッキーとUser-Agentを使用してリクエストを行う方法
    try {
        const cfCookie = solution.cookies.map(cookie => `${cookie.name}=${cookie.value}`).join('; ');
        
        console.log('\n取得したクッキーとUser-Agentを使用してターゲットページにアクセスしています...');
        const pageResponse = await axios.get(PAGE_URL, {
            headers: {
                'User-Agent': solution.userAgent,
                'Cookie': cfCookie
            },
            // 以降のリクエストに専用のプロキシ対応のaxiosインスタンスを使用することを推奨します。
            proxy: false, 
        });

        console.log(`\n正常にアクセスできました!ページのステータスコード: ${pageResponse.status}`);
        // console.log('ページのコンテンツ:', pageResponse.data); // コンテンツを確認するにはコメントを外してください

    } catch (error) {
        console.error(`解決を使用してページにアクセス中にエラーが発生しました: ${error.response ? error.response.status : error.message}`);
    }
}

main();

⚠️ 変更する必要がある重要な変数

コードを実行する前に、次の変数を変更する必要があります:

  • PROXY: ここにプロキシサーバーのアドレスと資格情報を置き換えてください。形式はhttp://username:password@ip:portです。
  • CAPSOLVER_API_KEY: カップソルバーのダッシュボード でAPIキーを取得してください。
  • PAGE_URL: クラウドフレアで保護されているターゲットウェブサイトのURLに置き換えてください。

結論

カップソルバーを統合することで、開発者はNode.jsアプリケーション内でクラウドフレアチャレンジの複雑なプロセスを自動化できます。このアプローチは高い成功率を持ち、常に変化するセキュリティポリシーに対処する必要がありません。単にAPIを呼び出すだけで、cf_clearanceトークンと一致するUser-Agentを取得でき、ターゲットウェブサイトへのシームレスなアクセスが可能になります。この戦略は、安定した大規模なデータ収集を必要とするプロジェクトにとって不可欠です。詳細を知りたい場合は、クラウドフレア5秒チャレンジの解決方法に関するガイドをご覧ください。

よくある質問(FAQ)

Q1: なぜプロキシを使用する必要がありますか?
A1: クラウドフレアはIPアドレスを異常な活動に対して監視しています。1つのIPアドレスが多くのリクエストを送信すると、ボットとしてマークされる可能性があります。高品質なローテーションプロキシ(住宅プロキシやISPプロキシなど)を使用することで、リアルユーザーの行動を模倣し、成功確率を大幅に向上させることができます。

Q2: cf_clearanceトークンの有効期限はどのくらいですか?
A2: cf_clearanceトークンは通常、数時間有効です。ただし、正確な有効期間はウェブサイトのクラウドフレア設定によります。期限切れになると、新しいトークンを取得するためにプロセスを再度実行する必要があります。

Q3: 取得したクッキーをスクリーパーで使用できますか?
A3: はい。カップソルバーから解決を取得した後、すべての後続のHTTPリクエストにcf_clearanceクッキーと一致するUser-Agentを含める必要があります。解決に使用した同じプロキシIPを使用することが重要です。このガイドはNode.jsに焦点を当てていますが、他の言語でも同様の原則が適用されます。たとえば、PythonとSeleniumでクラウドフレアCAPTCHAを解決する方法については、別の投稿で説明しています。

Q4: カップソルバーは他の種類のCAPTCHAを処理できますか?
A4: カップソルバーはクラウドフレアに加え、さまざまなバージョンのreCAPTCHAや画像ベースのCAPTCHAをサポートしています。最新の解決策について知りたい場合は、2026年のクラウドフレアチャレンジソルバーのトップ10の性能ランキングをチェックしてください。サポートされているタイプの完全なリストについては、公式のカップソルバードキュメントを参照してください。

コンプライアンス免責事項: このブログで提供される情報は、情報提供のみを目的としています。CapSolverは、すべての適用される法律および規制の遵守に努めています。CapSolverネットワークの不法、詐欺、または悪用の目的での使用は厳格に禁止され、調査されます。私たちのキャプチャ解決ソリューションは、公共データのクローリング中にキャプチャの問題を解決する際に100%のコンプライアンスを確保しながら、ユーザーエクスペリエンスを向上させます。私たちは、サービスの責任ある使用を奨励します。詳細については、サービス利用規約およびプライバシーポリシーをご覧ください。

もっと見る

Cloudflare Turnstileを解決するためには`action`が必要かどうかを識別する方法 – CapSolver拡張機能を使用して
CapSolver拡張機能を使用してCloudflare Turnstileを解決する際に`action`が必要かどうかを確認する方法

クラウドフレア・ターニスティルの効果的なCAPTCHAの解決方法を学びます。Capsolverのツールとテクニックを使用するためのステップバイステップのガイドに従ってください。

Cloudflare
Logo of CapSolver

Nikolai Smirnov

05-Dec-2025

CloudflareチャレンジをNode.JSで解決する方法
CloudflareチャレンジをNode.jsで解決する方法

CloudflareがNode.jsスカッパーをブロックする理由と、開発者がデータワークフローでcf_clearanceを信頼性を持って取得する方法についての考察

Cloudflare
Logo of CapSolver

Sora Fujimoto

03-Dec-2025

Cloudflareを回避する方法 | PuppeteerとNode.jsを使って
cloudflareを解決する方法 | Puppeteer Node.JSを使用する

私たちは、PuppeteerとNode.jsを使用して、クラウドフレアのようなターニスティールを効果的に解決する方法を探索します。Captchaソルバーの助けを借りて。

Cloudflare
Logo of CapSolver

Ethan Collins

02-Dec-2025

CloudflareのチャレンジをSeleniumで自動化する方法
SeleniumでCloudflareチャレンジの回避方法

Cloudflareのチャレンジを解決するための決定的な戦略を習得してください。信頼性のあるウェブオートメーションのために、Undetected-Chromedriver、行動の模倣、およびCapSolverのAPIを使用してください。

Cloudflare
Logo of CapSolver

Sora Fujimoto

26-Nov-2025

Cloudflare Turnstile の見分け方 | CapSolver エクステンションを使用して
クラウドフレアのトゥルネスティールの識別方法 | キャップソルバーのエクステンションを使って

効果的なCAPTCHAの解決方法を学び、クラウドフレア・ターニースタイルを識別する方法をマスターしてください。カプソルバーのツールとテクニックを使用するためのステップバイステップのガイドに従ってください。

Cloudflare
Logo of CapSolver

Sora Fujimoto

19-Nov-2025

Cloudflare Turnstile と Challenge
2024年におけるクラウドフレアターニースタイルとチャレンジの解決方法

スクレイピングが必要なウェブサイトの約20%が、簡単にアクセスをブロックできる強力なボット対策保護システムであるCloudflareを採用しています...

Cloudflare
Logo of CapSolver

Sora Fujimoto

18-Nov-2025