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çenek | Varsayılan değer | Tanı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ı | 120 | reCAPTCHA 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ı | 600 | Saniye 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ığı | 10 | res.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çenek | Varsayılan değer | Tanım |
---|---|---|
sayısal | 0 | Captcha'nın sayısal veya başka simgeler içerip içermediğini tanımlar API belgelerinde daha fazla bilgi görün |
minUzunluk | 0 | minimum cevap uzunluğu |
maksUzunluk | 0 | maksimum cevap uzunluğu |
ifade | 0 | cevabın birden fazla kelime içerip içermediğini tanımlar |
harfe duyarlı | 0 | cevabın büyük/küçük harfe duyarlı olup olmadığını tanımlar |
hesapla | 0 | captcha'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 |
- Normal Captcha
- Text Captcha
- reCAPTCHA v2
- reCAPTCHA v3
- FunCaptcha
- GeeTest
- KeyCaptcha
- Capy
- Grid
- Canvas
- ClickCaptcha
- Döndür
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.
Bu yöntem, açık metin olarak sağlanan bir soruyu yanıtlamayı gerektiren bir captcha'yı atlamak için kullanılabilir.
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',
]);
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 (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 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'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 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 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');
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 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');
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
}