Reference

CaptchaAI in der Produktion: Leitfaden zur Konfigurationsverwaltung

Hartcodierte API-Schlüssel und Zeitüberschreitungen funktionieren für Prototypen. Die Produktion erfordert eine umgebungsspezifische Konfiguration, Geheimnisverwaltung und die Möglichkeit, Einstellungen ohne erneute Bereitstellung zu ändern.

Konfigurationshierarchie

Priority (highest → lowest):

1. Environment variables     ← deployment-specific overrides
2. Config file (YAML/JSON)   ← version-controlled defaults
3. Application defaults      ← fallback values in code

Vollständige Konfigurationsreferenz

Parameter Umgebungsvariable Standard Beschreibung
API-Schlüssel CAPTCHAAI_API_KEY Erforderlich. Ihr CaptchaAI-API-Schlüssel
URL senden CAPTCHAAI_SUBMIT_URL https://ocr.captchaai.com/in.php Endpunkt für die Aufgabenübermittlung
Umfrage-URL CAPTCHAAI_POLL_URL https://ocr.captchaai.com/res.php Endpunkt der Ergebnisabfrage
Abfrageintervall CAPTCHAAI_POLL_INTERVAL 5 Sekunden zwischen Abfrageversuchen
Maximale Anzahl an Umfrageversuchen CAPTCHAAI_MAX_POLLS 60 Maximale Abfrageversuche vor dem Timeout
Parallelität CAPTCHAAI_CONCURRENCY 10 Maximale parallele CAPTCHA-Aufgaben
Auszeit CAPTCHAAI_TIMEOUT 300 Gesamt-Timeout in Sekunden
Stellvertreter CAPTCHAAI_PROXY Proxy-URL zum Lösen von CAPTCHAs
Rückruf-URL CAPTCHAAI_CALLBACK_URL Webhook-URL für asynchrone Ergebnisse
Wiederholungsversuche CAPTCHAAI_RETRIES 3 Wiederholte Versuche bei vorübergehenden Fehlern
Protokollebene CAPTCHAAI_LOG_LEVEL info Ausführlichkeit protokollieren

Konfigurationslader

Python

import os
import yaml
from dataclasses import dataclass, field
from pathlib import Path


@dataclass
class CaptchaAIConfig:
    api_key: str = ""
    submit_url: str = "https://ocr.captchaai.com/in.php"
    poll_url: str = "https://ocr.captchaai.com/res.php"
    poll_interval: int = 5
    max_polls: int = 60
    concurrency: int = 10
    timeout: int = 300
    proxy: str = ""
    callback_url: str = ""
    retries: int = 3
    log_level: str = "info"

    @classmethod
    def load(cls, config_path=None):
        """Load config: env vars override file, which overrides defaults."""
        config = cls()

        # Layer 2: Config file
        if config_path and Path(config_path).exists():
            with open(config_path) as f:
                file_config = yaml.safe_load(f) or {}
            for key, value in file_config.items():
                if hasattr(config, key):
                    setattr(config, key, value)

        # Layer 1: Environment variables (highest priority)
        env_map = {
            "CAPTCHAAI_API_KEY": "api_key",
            "CAPTCHAAI_SUBMIT_URL": "submit_url",
            "CAPTCHAAI_POLL_URL": "poll_url",
            "CAPTCHAAI_POLL_INTERVAL": "poll_interval",
            "CAPTCHAAI_MAX_POLLS": "max_polls",
            "CAPTCHAAI_CONCURRENCY": "concurrency",
            "CAPTCHAAI_TIMEOUT": "timeout",
            "CAPTCHAAI_PROXY": "proxy",
            "CAPTCHAAI_CALLBACK_URL": "callback_url",
            "CAPTCHAAI_RETRIES": "retries",
            "CAPTCHAAI_LOG_LEVEL": "log_level",
        }

        for env_key, attr_name in env_map.items():
            value = os.environ.get(env_key)
            if value is not None:
                # Cast to correct type
                current = getattr(config, attr_name)
                if isinstance(current, int):
                    value = int(value)
                setattr(config, attr_name, value)

        config.validate()
        return config

    def validate(self):
        if not self.api_key:
            raise ValueError("CAPTCHAAI_API_KEY is required")
        if self.poll_interval < 1:
            raise ValueError("poll_interval must be >= 1")
        if self.concurrency < 1:
            raise ValueError("concurrency must be >= 1")


# Usage
config = CaptchaAIConfig.load("config/captchaai.yaml")
print(f"Concurrency: {config.concurrency}, Timeout: {config.timeout}s")

JavaScript

const fs = require("fs");
const yaml = require("js-yaml");
const path = require("path");

class CaptchaAIConfig {
  static defaults = {
    apiKey: "",
    submitUrl: "https://ocr.captchaai.com/in.php",
    pollUrl: "https://ocr.captchaai.com/res.php",
    pollInterval: 5,
    maxPolls: 60,
    concurrency: 10,
    timeout: 300,
    proxy: "",
    callbackUrl: "",
    retries: 3,
    logLevel: "info",
  };

  static envMap = {
    CAPTCHAAI_API_KEY: "apiKey",
    CAPTCHAAI_SUBMIT_URL: "submitUrl",
    CAPTCHAAI_POLL_URL: "pollUrl",
    CAPTCHAAI_POLL_INTERVAL: { key: "pollInterval", type: "int" },
    CAPTCHAAI_MAX_POLLS: { key: "maxPolls", type: "int" },
    CAPTCHAAI_CONCURRENCY: { key: "concurrency", type: "int" },
    CAPTCHAAI_TIMEOUT: { key: "timeout", type: "int" },
    CAPTCHAAI_PROXY: "proxy",
    CAPTCHAAI_CALLBACK_URL: "callbackUrl",
    CAPTCHAAI_RETRIES: { key: "retries", type: "int" },
    CAPTCHAAI_LOG_LEVEL: "logLevel",
  };

  static load(configPath = null) {
    let config = { ...CaptchaAIConfig.defaults };

    // Layer 2: Config file
    if (configPath && fs.existsSync(configPath)) {
      const ext = path.extname(configPath);
      const raw = fs.readFileSync(configPath, "utf8");
      const fileConfig = ext === ".json" ? JSON.parse(raw) : yaml.load(raw);
      config = { ...config, ...fileConfig };
    }

    // Layer 1: Environment variables
    for (const [envKey, mapping] of Object.entries(CaptchaAIConfig.envMap)) {
      const value = process.env[envKey];
      if (value !== undefined) {
        const attrKey = typeof mapping === "string" ? mapping : mapping.key;
        const type = typeof mapping === "string" ? "string" : mapping.type;
        config[attrKey] = type === "int" ? parseInt(value, 10) : value;
      }
    }

    CaptchaAIConfig.validate(config);
    return config;
  }

  static validate(config) {
    if (!config.apiKey) throw new Error("CAPTCHAAI_API_KEY is required");
    if (config.pollInterval < 1) throw new Error("pollInterval must be >= 1");
    if (config.concurrency < 1) throw new Error("concurrency must be >= 1");
  }
}

// Usage
const config = CaptchaAIConfig.load("config/captchaai.yaml");
console.log(`Concurrency: ${config.concurrency}, Timeout: ${config.timeout}s`);

Konfigurationsdateien pro Umgebung

# config/captchaai.yaml — base
api_key: ""  # Always set via env var
concurrency: 5
poll_interval: 5
retries: 3
log_level: info
# config/captchaai.production.yaml
concurrency: 20
poll_interval: 3
timeout: 180
log_level: warning
# config/captchaai.staging.yaml
concurrency: 3
poll_interval: 5
timeout: 300
log_level: debug

Geheimnismanagement

Speichern Sie API-Schlüssel niemals in Konfigurationsdateien oder der Quellcodeverwaltung.

Methode Am besten für Beispiel
Umgebungsvariablen Container, CI/CD export CAPTCHAAI_API_KEY=abc123
AWS Secrets Manager AWS-Infrastruktur Beim Start abrufen; automatische Rotation
HashiCorp-Tresor Multi-Cloud, vor Ort Dynamische Geheimnisse mit TTL
Docker-Geheimnisse Docker Swarm / Compose Auf /run/secrets/ montiert
.env-Datei (nur Entwickler) Lokale Entwicklung dotenv-Bibliothek; .gitignore es

Docker Compose-Beispiel

services:
  captcha-worker:
    image: captcha-worker:latest
    environment:

      - CAPTCHAAI_API_KEY=${CAPTCHAAI_API_KEY}
      - CAPTCHAAI_CONCURRENCY=15
      - CAPTCHAAI_LOG_LEVEL=warning
    env_file:

      - .env.production

Feature-Flags

Schalten Sie Funktionen um, ohne sie erneut bereitzustellen:

class FeatureFlags:
    def __init__(self):
        self.flags = {
            "use_callback": os.environ.get("FF_USE_CALLBACK", "false") == "true",
            "enable_proxy": os.environ.get("FF_ENABLE_PROXY", "true") == "true",
            "max_concurrent": int(os.environ.get("FF_MAX_CONCURRENT", "10")),
        }

    def is_enabled(self, flag):
        return self.flags.get(flag, False)

    def get(self, flag, default=None):
        return self.flags.get(flag, default)

Fehlerbehebung

Problem Ursache Lösung
Ergebnis passt nicht zum eigenen Fall Solver-Typ oder Eingabeparameter wurden falsch auf den Zieltyp gemappt Vergleiche Zielseite, Solver-Methode und Pflichtparameter noch einmal systematisch
Beispiel läuft, aber Produktion scheitert Session, Header oder Proxy-Kontext weichen vom Test ab Übertrage erfolgreiche Testbedingungen möglichst unverändert in den Live-Workflow
Fehler bleiben unklar Logs enthalten zu wenig Kontext für eine belastbare Diagnose Protokolliere Solver-Typ, Latenz, Fehlercode und Downstream-Reaktion gemeinsam

Verwandte Leitfäden

  • CaptchaAI-Anmeldedaten mit Umgebungsvariablen sichern
  • IP-Whitelisting und API-Schlüsselsicherheit
  • CaptchaAI-API-Schlüsselrotation
Kommentare sind für diesen Artikel deaktiviert.

Verwandte Beiträge

Explainers User-Agent-Verwaltung für CAPTCHA-Lösungsworkflows
User-Agent-Verwaltung für CAPTCHA-Lösungs-Workflows: Browser-Fingerprint optimieren und Erkennung vermeiden.

User-Agent-Verwaltung für CAPTCHA-Lösungs-Workflows: Browser-Fingerprint optimieren und Erkennung vermeiden.

May 01, 2026
Explainers Auswirkungen der DNS-Auflösung auf die Leistung der CAPTCHA-API
DNS-Auflösung und ihre Auswirkungen auf die CAPTCHA-API-Performance: Latenzmessung, DNS-Caching und Optimierungsstrategien für Captcha AI.

DNS-Auflösung und ihre Auswirkungen auf die CAPTCHA-API-Performance: Latenzmessung, DNS-Caching und Optimierun...

Apr 24, 2026