PHP ile captcha'yı atlayın

PHP ile captcha'yı atlayın

Captcha atlama otomasyon çözümü için PHP paketini entegre edin. En başarılı captcha tanıma oranı.

reCAPTCHA, Arkose captcha, GeetestAtlamak için 2Captcha captcha çözme hizmetinin API'si ile kolay entegrasyon için PHP paketi ve diğer captcha'ları çözün

Hızlı başlangıç

Kurulum

Komut dosyası paketi, paket yükleyici kullanılarak veya manuel olarak kurulabilir.

Composer

Bir kitaplık paketini otomatik olarak kurmak için PHP paketleri için standart bir çözüm olan Composer'ı kullanmanız gerekir. bağlantıdan indirin ve talimatlara göre yükleyin. Uygulamayı yükledikten sonra şu komutu kullanın:

composer require 2captcha/2captcha

Manuel

src klasörünün içeriğini projenize indirin ve src/autoloader.php otomatik yükleyicisini şu komutla etkinleştirin:

require 'path/to/autoloader.php';

Sizi, aşağıdakiler için kitaplıklar ve modüller bulabileceğiniz GitHub depomuzu keşfetmeye davet ediyoruz. API'miz ile kolay entegrasyon.

Yapılandırma

Kurulu paketi yapılandırmak için gerekli tüm parametrelerin açıklaması

TwoCaptcha sınıfının bir örneği şu şekilde oluşturulabilir:

$solver = new \TwoCaptcha\TwoCaptcha('YOUR_API_KEY');

Ayrıca, oluşturulan örnek için bazı seçenekleri özelleştirebilirsiniz:

$solver = new \TwoCaptcha\TwoCaptcha([
    'apiKey'           => 'YOUR_API_KEY',
    'softId'           => 123,
    'callback'         => 'https://your.site/result-receiver',
    'defaultTimeout'   => 120,
    'recaptchaTimeout' => 600,
    'pollingInterval'  => 10,
]);
TwoCaptcha örnek seçenekleri
SeçenekVarsayılan değerTanım
softId-2Captcha yazılım kataloğunda yayınladıktan sonra elde edilen yazılım kimliğiniz
callback-Captcha tanıma sonucunu alan web sunucunuzun URL'si. URL önce hesabınızın pingback ayarlarına kaydedilmelidir.
varsayılanZaman aşımı120reCAPTCHA dışındaki tüm captcha türleri için saniye cinsinden yoklama zaman aşımı. Modülün yanıtı res.php API uç noktasından ne kadar süreyle almaya çalıştığını tanımlar.
recaptchaZamanaşımı600Saniye cinsinden reCAPTCHA için yoklama zaman aşımı. Modülün yanıtı res.php API uç noktasından ne kadar süreyle almaya çalıştığını tanımlar.
yoklamaAralığı10res.php API uç noktasına yapılan istekler arasındaki saniye cinsinden aralık, değerlerin 5 saniyeden kısa ayarlanması önerilmez
ÖNEMLİ: callback, TwoCaptcha örneği için tanımlandıktan sonra, tüm yöntemler yalnızca captcha kimliğini ve DO'yu döndürür Sonucu almak için API'yi yoklamayın. Sonuç, geri arama URL'sine gönderilecektir. Cevabı manuel olarak almak için Sonucu al yöntemini kullanın.

Captcha'yı çöz

Herhangi bir resim tabanlı captcha gönderdiğinizde, 2Captcha çalışanlarının sorunu düzgün bir şekilde çözmesine yardımcı olacak ek seçenekler sunabilir.

Captcha seçenekleri
SeçenekVarsayılan değerTanım
sayısal0Captcha'nın sayısal veya başka simgeler içerip içermediğini tanımlar API belgelerinde daha fazla bilgi görün
minUzunluk0minimum cevap uzunluğu
maksUzunluk0maksimum cevap uzunluğu
ifade0cevabın birden fazla kelime içerip içermediğini tanımlar
harfe duyarlı0cevabın büyük/küçük harfe duyarlı olup olmadığını tanımlar
hesapla0captcha'yı tanımlar hesaplama gerektirir
dil-captcha dilini tanımlar, desteklenen dillerin listesine bakın
hintImg-captcha ile çalışanlara gösterilen ipucu içeren bir resim
ipucu Metin-captcha ile çalışanlara gösterilen ipucu veya görev metni
basitCaptcha

Normal bir captcha'yı (görüntüdeki bozuk metin) atlamak için aşağıdaki yöntemi kullanın. Bu yöntem aynı zamanda görüntüdeki herhangi bir metni tanımak için de kullanılabilir.

metinCaptcha

Bu yöntem, açık metin olarak sağlanan bir soruyu yanıtlamayı gerektiren bir captcha'yı atlamak için kullanılabilir.

recaptchaV2

reCAPTCHA V2'yi çözmek ve korumayı atlamak için bir belirteç almak için bu yöntemi kullanın.

$result = $solver->recaptcha([
    'sitekey' => '6Le-wvkSVVABCPBMRTvw0Q4Muexq1bi0DJwx_mJ-',
    'url'     => 'https://mysite.com/page/with/recaptcha',
]);
recaptchaV3

Bu yöntem, reCAPTCHA V3 çözücü sağlar ve bir belirteç döndürür.

$result = $solver->recaptcha([
    'sitekey' => '6Le-wvkSVVABCPBMRTvw0Q4Muexq1bi0DJwx_mJ-',
    'url'     => 'https://mysite.com/page/with/recaptcha',
    'version' => 'v3',
]);
funCaptcha

FunCaptcha (Arkoselabs) çözme yöntemi. Bir belirteç döndürür.

$result = $solver->funcaptcha([
    'sitekey' => '6Le-wvkSVVABCPBMRTvw0Q4Muexq1bi0DJwx_mJ-',
    'url'     => 'https://mysite.com/page/with/funcaptcha',
]);
geeTest

GeeTest bulmacası captcha'yı çözme yöntemi. JSON olarak bir dizi belirteç döndürür.

$result = $solver->geetest([
    'gt'        => 'f1ab2cdefa3456789012345b6c78d90e',
    'challenge' => '12345678abc90123d45678ef90123a456b',
    'url'       => 'https://www.site.com/page/',
]);
keyCaptcha

KeyCaptcha'yı çözmek için belirteç tabanlı yöntem.

$result = $solver->keycaptcha([
    's_s_c_user_id'          => 10,
    's_s_c_session_id'       => '493e52c37c10c2bcdf4a00cbc9ccd1e8',
    's_s_c_web_server_sign'  => '9006dc725760858e4c0715b835472f22-pz-',
    's_s_c_web_server_sign2' => '2ca3abe86d90c6142d5571db98af6714',
    'url'                    => 'https://www.keycaptcha.ru/demo-magnetic/',
]);
capy

Capy bulmacası captcha'sını atlamak için jeton tabanlı yöntem.

$result = $solver->capy([
    'sitekey' => 'PUZZLE_Abc1dEFghIJKLM2no34P56q7rStu8v',
    'url'     => 'http://mysite.com/',
    'api_server' => 'https://jp.api.capy.me/',
]);
grid

Grid yöntemi orijinal olarak Eski reCAPTCHA V2 yöntemi olarak adlandırılır. Yöntem, görüntüye bir ızgara uygulayabileceğiniz ve belirli ızgara kutularına tıklamanız gereken herhangi bir tür captcha'yı atlamak için kullanılabilir. Kutu numaralarını döndürür.

$result = $solver->grid('path/to/captcha.jpg');
canvas

Kanvas yöntemi, resim üzerinde bir nesnenin çevresine bir çizgi çizmeniz gerektiğinde kullanılabilir. Bir çokgen çizmek için bir dizi noktanın koordinatlarını döndürür.

$result = $solver->canvas('path/to/captcha.jpg');
clickCaptcha

ClickCaptcha yöntemi, captcha görüntüsündeki noktaların koordinatlarını döndürür. Resmin belirli noktalarına tıklamanız gerekirse kullanılabilir

$result = $solver->coordinates('path/to/captcha.jpg');
rotateCaptcha

Bu yöntem, bir nesneyi döndürmeyi isteyen bir captcha'yı çözmek için kullanılabilir. Çoğunlukla FunCaptcha'yı atlamak için kullanılır. Dönme açısını döndürür.

$result = $solver->rotate('path/to/captcha.jpg');

Diğer metodlar

Ana komut dosyalarının çalışması sırasında kullanılan ek geçerli yöntemler

send / getResult

Bu yöntemler, manuel captcha gönderimi ve yanıt yoklaması için kullanılabilir.

$id = $solver->send(['file' => 'path/to/captcha.jpg', ...]);

sleep(20);

$code = $solver->getResult($id);

balance

Hesabınızın bakiyesini almak için bu yöntemi kullanın.

$balance = $solver->balance();

report

İyi veya kötü captcha yanıtını bildirmek için bu yöntemi kullanın.

$solver->report($id, true); // captcha solved correctly
$solver->report($id, false); // captcha solved incorrectly

Hata yönetimi

İstekler işlenirken hizmet tarafından döndürülen standart hataların olası çeşitleri

Bir hata durumunda, captcha çözücü bir istisna atar. Bu vakaları uygun şekilde ele almak önemlidir. İstisnaları işlemek için dene/yakala kullanmanızı öneririz.

try {
    $result = $solver->text('If tomorrow is Saturday, what day is today?');
} catch (\TwoCaptcha\Exception\ValidationException $e) {
    // invalid parameters passed
} catch (\TwoCaptcha\Exception\NetworkException $e) {
    // network error occurred
} catch (\TwoCaptcha\Exception\ApiException $e) {
    // api respond with error
} catch (\TwoCaptcha\Exception\TimeoutException $e) {
    // captcha is not solved so far
}

Hizmet API'si ile entegrasyon için diğer diller