Go'yu kullanarak captcha'yı atla
Captcha'yı Go lang modülüyle çevrimiçi çözün.
reCAPTCHA, Arkose captcha, GeetestAtlamak için 2Captcha captcha çözme hizmetinin API'si ile kolay entegrasyon için Golang 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.
GitHub
API istemcisini kurmak için şunu kullanın:
go get -u github.com/2captcha/2captcha-go
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ı
Müşteri
örneği şu şekilde oluşturulabilir:
client := api2captcha.NewClient('YOUR_API_KEY')
Ayrıca, oluşturulan örnek için bazı seçenekleri özelleştirebilirsiniz:
client.SoftId = 123
client.Callback = "https://your.site/result-receiver"
client.DefaultTimeout = 120
client.RecaptchaTimeout = 600
client.PollingInterval = 100
Müşteri örneği 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İ:Müşteri
örneği içingeri arama
tanımlandıktan sonra, tüm yöntemler yalnızca captcha kimliğini döndürür ve 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 |
Temel örnek
Aşağıdaki örnek, hata işleme ile temel bir çözücü çağrısı örneğini göstermektedir.
cap := api2captcha.Normal{
File: "/path/to/normal.jpg",
}
code, err := client.Solve(cap.ToRequest())
if err != nil {
if err == api2captcha.ErrTimeout {
log.Fatal("Timeout");
} else if err == api2captcha.ErrApi {
log.Fatal("API error");
} else if err == api2captcha.ErrNetwork {
log.Fatal("Network error");
} else {
log.Fatal(err);
}
}
fmt.Println("code "+code)
- 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.
cap := api2captcha.ReCaptcha{
SiteKey: "6Le-wvkSVVABCPBMRTvw0Q4Muexq1bi0DJwx_mJ-",
Url: "https://mysite.com/page/with/recaptcha",
Invisible: true,
Action: "verify",
}
req := cap.ToRequest()
req.SetProxy("HTTPS", "login:password@IP_address:PORT")
code, err := client.solve(req)
Bu yöntem, reCAPTCHA V3 çözücü sağlar ve bir belirteç döndürür.
cap := api2captcha.ReCaptcha{
SiteKey: "6Le-wvkSVVABCPBMRTvw0Q4Muexq1bi0DJwx_mJ-",
Url: "https://mysite.com/page/with/recaptcha",
Version: "v3",
Action: "verify",
Score: 0.3,
}
req := cap.ToRequest()
req.SetProxy("HTTPS", "login:password@IP_address:PORT")
code, err := client.solve(req)
FunCaptcha (Arkoselabs) çözme yöntemi. Bir belirteç döndürür.
cap := api2captcha.FunCaptcha{
SiteKey: "69A21A01-CC7B-B9C6-0F9A-E7FA06677FFC",
Url: "https://mysite.com/page/with/funcaptcha",
Surl: "https://client-api.arkoselabs.com",
UserAgent: "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.61 Safari/537.36",
Data: map[string]string{"anyKey":"anyValue"},
}
req := cap.ToRequest()
req.SetProxy("HTTPS", "login:password@IP_address:PORT")
code, err := client.solve(req)
GeeTest bulmacası captcha'yı çözme yöntemi. JSON olarak bir dizi belirteç döndürür.
cap := api2captcha.GeeTest{
GT: "f2ae6cadcf7886856696502e1d55e00c",
ApiServer: "api-na.geetest.com",
Challenge: "12345678abc90123d45678ef90123a456b",
Url: "https://mysite.com/captcha.html",
}
req := cap.ToRequest()
req.SetProxy("HTTPS", "login:password@IP_address:PORT")
code, err := client.solve(req)
KeyCaptcha'yı çözmek için belirteç tabanlı yöntem.
cap := api2captcha.KeyCaptcha{
UserId: 10,
SessionId: "493e52c37c10c2bcdf4a00cbc9ccd1e8",
WebServerSign: "9006dc725760858e4c0715b835472f22",
WebServerSign2: "9006dc725760858e4c0715b835472f22",
Url: "https://www.keycaptcha.ru/demo-magnetic/",
}
req := cap.ToRequest()
req.SetProxy("HTTPS", "login:password@IP_address:PORT")
code, err := client.solve(req)
Capy bulmacası captcha'sını atlamak için jeton tabanlı yöntem.
cap := api2captcha.Capy{
SiteKey: "PUZZLE_Abc1dEFghIJKLM2no34P56q7rStu8v",
Url: "https://www.mysite.com/captcha/",
}
req := cap.ToRequest()
req.SetProxy("HTTPS", "login:password@IP_address:PORT")
code, err := client.solve(req)
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.
cap := api2captcha.Grid{
File: "path/to/captcha.jpg",
Rows: 3,
Cols: 3,
PreviousId: 0,
CanSkip: false,
Lang: "en",
HintImageFile: "path/to/hint.jpg",
HintText: "Select all images with an Orange",
}
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.
cap := api2captcha.Canvas{
File: "path/to/captcha.jpg",
PreviousId: 0,
CanSkip: false,
Lang: "en",
HintImageFile: "path/to/hint.jpg",
HintText: "Draw around apple",
}
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
cap := api2captcha.Coordinates{
File: "path/to/captcha.jpg",
Lang: "en",
HintImageFile: "path/to/hint.jpg",
HintText: "Connect the dots",
}
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.
cap := api2captcha.Rotate{
File: "path/to/captcha.jpg",
Angle: 40,
Lang: "en",
HintImageFile: "path/to/hint.jpg",
HintText: "Put the images in the correct way",
}
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, err := client.Send(cap.ToRequest())
if err != nil {
log.Fatal(err);
}
time.Sleep(10 * time.Second)
code, err := client.GetResult(id)
if err != nil {
log.Fatal(err);
}
if code == nil {
log.Fatal("Not ready")
}
fmt.Println("code "+*code)
balance
Hesabınızın bakiyesini almak için bu yöntemi kullanın.
balance, err := client.GetBalance()
if err != nil {
log.Fatal(err);
}
report
İyi veya kötü captcha yanıtını bildirmek için bu yöntemi kullanın.
err := client.Report(id, true) // solved correctly
err := client.Report(id, false) // solved incorrectly