Overview
GeeTest captcha iOS SDK supports for native iOS. The SDK doesn’t contain any third-party library.
| Item | Description | 
|---|---|
| Product Name | GeeTest CAPTCHA v3 | 
| Developer | Wuhan Jiyi Network Technology Co., Ltd. | 
| Latest Version (JS) | v0.15.9 | 
| Latest Release Date | 2025/2/19 | 
| Main Function | GeeTest’s next-generation CAPTCHA goes beyond traditional “question-and-answer” verification, using advanced deep learning to analyze behavioral data and accurately distinguish humans from bots. | 
| Privacy Policy | GeeTest CAPTCHA v3 Privacy Policy | 
| Compliance Guide | GeeTest CAPTCHA v3 Compliance Guide | 
| Resource Links |  | 
Development environment
| Item | Description | 
|---|---|
| Target | iOS 9+ | 
| Development environment | Xcode 12+ | 
| Dependency | Webkit.framework | 
| Third-party dependency | None | 
Resources
| Item | Description | 
|---|---|
| Data communication flow chart | Data communication flow chart, Interaction flow chart | 
| SDK API reference | gt3-ios-docs or check the header files | 
| Error code | Error Code | 
Installation
Get SDK
Mannualy download SDK & Demo
Please contact customer service to download the latest SDK (in .zip format).
Get SDK via CocoaPods
Please add the following to the file named Podfile in your workspace
| pod 'GT3Captcha-iOS' | 
Get SDK via Swift Package Manager
Here are the details for your reference: https://github.com/GeeTeam/gt3-spm-repo
Import SDK
- If you add the SDK manually, please drag and drop the - GT3Captcha.frameworkinto the project and select- Copy items if needed. - Please use - Linked Frameworks and Librariesto import the framework。After you have added- GT3Captcha.frameworkinto the project, please check if- .frameworkhas been successfully added in- PROJECT -> Build Phases -> Linked Frameworks and Libraries. 
- For the - Categoryin static libraries, please add- -ObjCflag via- Build Settings->- Other Linker Flagsfor the corresponding target. Please add- -ObjCflag. If it doesn’t work, please add- -all_load. 
- SDK version 0.9.0 and later needs to add - GT3Captcha.Bundleto project. Drag and drop- GT3Captcha.Bundlefrom the- .zipto the project.
Apple has announced a new privacy policy for applications (including SDK) at WWDC23, and there is a separate session on this topic titled Get started with privacy manifests - WWDC23 - Videos - Apple Developer. On July 27th, Apple released a news article stating that starting in the fall of 2023, if a newly uploaded application uses relevant APIs that do not provide a privacy manifest, you will receive an email notification. Starting in the spring of 2024, privacy manifests will become a mandatory requirement. The APIs involved and the reasons for their use can be found in Describing use of required reason API | Apple Developer Documentation. If the reason for use is not listed, you can directly submit the specific usage reason. For instructions on how to create a new privacy manifest, please refer to Privacy manifest files | Apple Developer Documentation.
It is hereby stated that GeeTest captcha of the iOS SDK uses some functions to retrieve disk space for writing logs, involving the NSPrivacyAccessedAPICategoryDiskSpace.
Configuration
Please firstly integrate server SDK, configure the id and key (get from GeeTest dashboard) and implement API1 and API2 in the initial method.
To use the SDK, please firstly finish the following steps.
- Initialize captcha
- Start captcha
- Get the verification result
- Handle errors
There are two styles of captcha button integration. Please choose one of them.
- Use GT3CaptchaManagerand bind with users events (Bind GeeTest captcha to your custom button, i.e. invisible captcha)
- Use GT3CaptchaButton(Integrate with GeeTest captcha button)
Whatever integration method is used, the project must conform to  <GTCaptchaManagerDelegate> protocol to process verification results and the possible returned errors.
The following example shows how to integrate:
Compile and run your project
Compile your project and experience GeeTest captcha.
Visual presentation
- Bind GeeTest captcha to a custom button  
- Integrate with GeeTest captcha button  
Code examples
Initialize captcha and start captcha
Import static library GT3Captcha.framework in header files
Bind GeeTest captcha to a custom button
The following example bind the captcha with
UIButton
- Initialize captcha 
 Instantiate CAPTCHA manager- GTCaptchaManager. Call the register method in- GTCaptchaManagerto get register data.
 - (GT3CaptchaManager *)manager {
 if (!_manager) {
 _manager = [[GT3CaptchaManager alloc] initWithAPI1:api_1 API2:api_2 timeout:5.0];
 _manager.delegate = self;
 
 }
 return _manager;
 }
 - (instancetype)initWithFrame:(CGRect)frame {
 self = [super initWithFrame:frame];
 
 if (self) {
 [self.manager registerCaptcha:nil];
 }
 return self;
 }
- Start captcha - After finished with captcha initialization and register, call the following method to activate captcha. - [self.manager startGTCaptchaWithAnimated:YES]; 
Integrate with GeeTest captcha button (use GT3CaptchaButton in SDK)
The example integrate captcha with
ViewController
- Initialize captcha 
 Initial the instance of- GTCaptchaManagerand assign this instance to- GTCaptchaButton.Then, add the- GTCaptchaButtonto- [ViewController view].- - (void)viewWillAppear:(BOOL)animated { 
 [self createCaptcha];
 }
 - (void)createCaptcha {
 // Create a new instance of `GT3CaptchaManager`
 GT3CaptchaManager *captchaManager = [[GT3CaptchaManager alloc] initWithAPI1:<--Your api1--> API2:<--Your api2--> timeout:5.0];
 captchaManager.delegate = self;
 
 //debug mode
 // [captchaManager enableDebugMode:YES];
 
 // Create a new instance of `GT3CaptchaButton`. And add it to the view which you want.
 GT3CaptchaButton *captchaButton = [[GT3CaptchaButton alloc] initWithFrame:CGRectMake(0, 0, 300, 44) captchaManager:captchaManager];
 captchaButton.center = self.view.center;
 //Recommend to start the captcha directly
 [captchaButton registerCaptcha:nil];
 [self.view addSubview:captchaButton];
 }
- Start captcha - Click the captcha button or use the following method to activate captcha. - [captchaButton startCaptcha]; 
Get the verification result
Only after finishing the secondary verification, the verification process is complete. Please conform to  GTCaptchaManagerDelegate protocol and process the following delegate methods.
| - (void)gtCaptcha:(GT3CaptchaManager *)manager didReceiveSecondaryCaptchaData:(NSData *)data response:(NSURLResponse *)response error:(GT3Error *)error decisionHandler:(void (^)(GT3SecondaryCaptchaPolicy))decisionHandler { | 
Handle errors
During the verification process, there might be some errors. Please conform to  GTCaptchaManagerDelegate protocol and handle the errors with the following delegate methods.
| - (void)gtCaptcha:(GTCaptchaManager *)manager errorHandler:(GTError *)error { | 
Please check the link for the error codes. GT3Error
Optional captcha Delegate Methods
Modify API1 request
Since some companies might require authentication or custom parameters, you could use the following delegate methods to custom the API1 request.
| - (void)gtCaptcha:(GT3CaptchaManager *)manager willSendRequestAPI1:(NSURLRequest *)originalRequest withReplacedHandler:(void (^)(NSURLRequest *))replacedHandler { | 
Please check
AsyncButtonfile in the following link for custom API1 & API2 request example. Code Example
Modify API2 request
Since some companies might require authentication or custom parameters, you could use the following delegate methods to custom the API2 request.
| - (void)gtCaptcha:(GT3CaptchaManager *)manager willSendSecondaryCaptchaRequest:(NSURLRequest *)originalRequest withReplacedRequest:(void (^)(NSMutableURLRequest *))replacedRequest { | 
Please check
AsyncButtonfile in the following link for custom API1 & API2 request example. Code Example
Get verification parameters
To get the verification parameters, you can use the following delegate methods.
| - (void)gtCaptcha:(GT3CaptchaManager *)manager didReceiveCaptchaCode:(NSString *)code result:(NSDictionary *)result message:(NSString *)message { | 
Disable the default API1 request
Please refer to the following example to disable the default API1 request.
| - (BOOL)shouldUseDefaultRegisterAPI:(GT3CaptchaManager *)manager { | 
Since the API1 request has been disabled, please configure captcha parameters manually, otherwise you cannot start captcha.
| // dict contains gt, challenge, success, etc. | 
Disable the default API2 request
Please refer to the following example to disable the default API2 request.
| - (BOOL)shouldUseDefaultSecondaryValidate:(GT3CaptchaManager *)manager { | 
Discussion:
After the API2 request has been disabled, the verification result prompt in the captcha button depends on the code in gtCaptcha:didReceiveCaptchaCode:result:message:. The @"1" refers to verification success.
Other integrate method
After 0.13.0, developer could use GT3AsyncTaskProtocol and  registerCaptchaWithCustomAsyncTask:completion: to complete the process of API1 and API2 by custom.
If use registerCaptchaWithCustomAsyncTask:completion:, delegate methods below couldn’t be invoked:
- shouldUseDefaultRegisterAPI:
- gtCaptcha:willSendRequestAPI1:withReplacedHandler:
- gtCaptcha:didReceiveDataFromAPI1:withError:
- shouldUseDefaultSecondaryValidate:
- gtCaptcha:willSendSecondaryCaptchaRequest:withReplacedRequest:
Please check
AsyncTaskButton.mandDemoAyncTask.mfor more detail. Example project
Other APIs and Swift example project
Please check the API reference for further details.
Download Example & Docs
Please refer to the example project for more example-files. More Swift example could be find in
DefaultDemoViewController.swiftandAsyncTaskViewController.swift.