在线调试
填写业务相关参数免费在线调试
此为接口总和文档,可以根据链接去找到对应的测试以及对接文档!
全接口无使用次数限制VIP->单独包月->次数包->点数计费->账户余额->免费额度
免费/测试用户请求频率限制 | 请求频率总限制 | 每日请求次数总限制 |
---|---|---|
0秒0次 每个免费用户的QPS总限制 | 1秒1次 每个用户QPS总限制 | 10000 (次) 每个用户每日请求总次数 |
返回格式:application/json
请求方式:HTTPGETPOST/JSON
请求示例:
Demo下载地址:点我下载
扣费规则:0.00005/元 = 1积分,按每次返回code = 1时才会扣费
注:如有同类型例图识别率下降请联系管理员!
公众号:微信搜索"图之腾"
名称 | 类型 | 说明 |
---|---|---|
CODE | INT | 状态码 |
MSG | STRING | 状态信息 |
DATA | STRING | 请求结果数据集 |
UUID | STRING | 任务ID |
接口ID列表(副标题需求为无代表不需要传title值):
识别合集-1:
接口名称 | 接口地址 | 接口价格 | 是否需要副标题 | 对应旧API(建议全部换新API,价格大部分优惠一些,速度会更快,后续旧API将关闭!) | 例图 |
---|---|---|---|---|---|
旋转图片 | 点击跳转 | 0.008元=160积分 | 否 | 图片旋转-1001(请先咨询开发者是否使用的此接口!买错概不负责!) | ![]() |
点选文字 | 点击跳转 | 0.009元=180积分 | 图片标题 | 文字点选类-1001 | 主图: 标题图: |
点选文字2 | 点击跳转 | 0.009元=180积分 | 暂无对应 | 主图:![]() |
识别合集-2:
接口名称 | 接口地址 | 接口价格 | 是否需要副标题 | 对应旧API(建议全部换新API,价格大部分优惠一些,速度会更快,后续旧API将关闭!) | 例图 |
---|---|---|---|---|---|
文字点选-1 | 点击跳转 | 0.009元=180积分 | 标题文字 | 图标点选类-2001 | ![]() |
图标点选-1 | 点击跳转 | 0.009元=180积分 | 无标题 | 图标点选类-2001 | ![]() |
空间推理 | 点击跳转 | 0.009元=180积分 | 标题文字 | 空间推理-2001 | ![]() |
拼图推理 | 点击跳转 | 0.01元=200积分 | 无标题 | 暂无对应 | ![]() |
滑块缺口 | 点击跳转 | 0.007元=140积分 | 无标题 | 滑块缺口类-2001 | ![]() |
识别合集-3:
接口名称 | 接口ID | 接口价格 | 是否需要副标题 | 对应旧API(建议全部换新API,价格大部分优惠一些,速度会更快,后续旧API将关闭!) | 例图 |
---|---|---|---|---|---|
汉字语序点选-1 | 点击跳转 | 0.009元=180积分 | 无标题 | 文字点选类【语序】-3011 | ![]() |
汉字点选-1(非语序) | 点击跳转 | 0.009元=180积分 | 无标题 | 文字点选类-3001 | ![]() |
图标点选-1 | 点击跳转 | 0.009元=180积分 | 无标题 | 图标点选类-3001 | ![]() |
九宫格-1 | 点击跳转 | 0.009元=180积分 | 无标题 | 图标点选类【九宫格】-3031 | ![]() |
空间推理-1 | 点击跳转 | 0.01元=200积分 | 文字标题 | 空间推理类-3001 | ![]() |
识别合集-4:
接口名称 | 接口ID | 接口价格 | 是否需要副标题 | 对应旧API(建议全部换新API,价格大部分优惠一些,速度会更快,后续旧API将关闭!) | 例图 |
---|---|---|---|---|---|
汉字语序点选-1 | 点击跳转 | 0.009元=180积分 | 无标题 | 文字点选类【语序】-3012 | ![]() |
汉字点选(非语序)-1 | 点击跳转 | 0.009元=180积分 | 标题图片 | 文字点选类-3002 | 主图: 标题图: |
图标点选-1 | 点击跳转 | 0.009元=180积分 | 标题图片 | 图标点选类-3002 | 主图: 标题图: |
九宫格点选-1 | 点击跳转 | 0.009元=180积分 | 标题图片 | 图标点选类【九宫格】-3032 | 主图: 标题图: |
图标点选-2 | 点击跳转 | 0.01元=200积分 | 标题图片 | 暂无对应 | 主图: 标题图: |
图标点选-3 | 点击跳转 | 0.012元=240积分 | 标题图片 | 暂无对应 | 主图: 标题图: |
方向图标点选-01 | 点击跳转 | 0.012元=240积分 | 标题图片 | 暂无对应 | 主图: 标题图: |
滑块缺口 | 点击跳转 | 0.0007元=140积分 | 无标题 | 滑块缺口类-3001 | ![]() |
识别合集-5:
接口名称 | 接口ID | 接口价格 | 是否需要副标题 | 例图 |
---|---|---|---|---|
文字点选-1 | 点击跳转 | 0.009元=180积分 | 标题图片 | 主图: 标题图: |
双圈旋转-01 | 点击跳转 | 0.008元=160积分 | 标题图片 | 主图: 标题图: |
识别合集-6:
接口名称 | 接口ID | 接口价格 | 是否需要副标题 | 例图 |
---|---|---|---|---|
滑块缺口 | 点击跳转 | 0.0008元=160积分 | 缺口图片 | 主图: 标题图: |
识别合集-7:
接口名称 | 接口ID | 接口价格 | 是否需要副标题 | 例图 |
---|---|---|---|---|
文字点选-1 | 点击跳转 | 180=0.009 | 无标题 | ![]() |
识别合集-8:
接口名称 | 接口ID | 接口价格 | 是否需要副标题 | 例图 |
---|---|---|---|---|
图标匹配-1 | 点击跳转 | 0.012元=240积分 | 无标题 | ![]() |
Recaptcha3*3 | 点击跳转 | 0.012元=240积分 | 文本标题 | ![]() |
通用合集-1(有的识别率不高!):
接口名称 | 接口ID | 接口价格 | 是否需要副标题 | 例图 |
---|---|---|---|---|
通用滑块-1(识别率不高) | 点我跳转 | 0.0025元=50积分 | 无标题 | ![]() |
通用点选-01 | 点击跳转 | 0.0025元=50积分 | 文本标题 | ![]() |
英中数识别(有的识别率不高!):
接口名称 | 接口地址 | 接口价格 | 是否需要副标题 | 例图 |
---|---|---|---|---|
21四字验证码 | 点击跳转 | 0.0025元=50积分 | 无标题 | ![]() |
APPLE四字验证码 | 点击跳转 | 0.0025元=50积分 | 无标题 | ![]() |
通用文本识别 | 点击跳转 | 0.0025元=50积分 | 无标题 | 暂无例图 |
错误码 | 类型 | 说明 |
---|---|---|
403 | int | 没有权限 |
422 | int | 超出请求限制 |
420 | int | 账户被封禁 |
1 | int | 成功返回 |
10001 | int | 用户不存在 |
10002 | int | sign值校验失败 |
10003 | int | 不在IP白名单内,禁止访问 |
10004 | int | 余额不足 |
10005 | int | 此接口需要实名 |
10006 | int | key参数未填写 |
10007 | int | 参数错误 |
10008 | int | 服务端错误,请联系管理员 |
10009 | int | 缺少参数 |
10010 | int | 系统错误类型2 |
10011 | int | 扣费失败 |
10012 | int | 模型ID错误 |
10013 | int | 识别失败 |
10014 | int | 服务端或客户传入代理访问不通 |
<?php
/**
* API请求DEMO
*
* 本demo支持GET与POST请求,同时支持签名验证与无需签名。
*/
//你申请的key密钥
$API_KEY = '你的接口密钥,登录控制台后在密钥管理页面申请';
//API接口地址
$API_URL = '';
$get_post_data = array(
//接口参数,一行一个,可按照接口文档-请求参数 的参数填写,或者直接复制开发工具下面的测试代码。
'key' => $API_KEY,
'参数名' => '参数值',
);
//签名校验的 SK:(在用户控制台https://www.tutengai.com/user/key的秘钥安全设置->签名校验 开启后才会生效,没开启签名校验留空即可。)
$sk = '56777ab62ff752fbd57ab7228fc2fc43';
/*发起请求API接口:
第1个参数:API接口地址URL,跟上面的同名变量相对应,无需更改。
第2个参数:API接口参数数组,跟上面的同名变量相对应,无需更改。
第3个参数:请求协议(GET或POST),一般默认GET,部分接口需要POST请求,根据实际情况修改为POST即可。
第4个参数:是否验证签名,true验证签名,否则false不验证签名,根据用户控制台 https://www.tutengai.com/user/key 的 秘钥安全设置->签名校验 开启后才会生效,如没开启,填写false即可。
第5个参数:如果第4个参数开启验证签名,此处必须填写 SK ,跟上面的同名变量相对应,无需更改。
*/
$resdata = api::send($API_URL, $get_post_data, 'GET', true, $sk); //发起请求,注意这里要选择接口支持的协议,默认GET,可选POST
//打印请求结果
print($resdata);
///////////////你的业务代码可写在这里处理API返回的数据
/**
* API请求类
*/
class api
{
public static function send($API_URL, $get_post_data, $type, $ifsign, $sk)
{
$get_post_data = http_build_query($get_post_data);
if ($ifsign) {
$sign = md5($get_post_data . $sk);
$res = self::send_curl($API_URL, $type, $get_post_data, $sign);
} else {
$res = self::send_curl($API_URL, $type, $get_post_data, null);
}
return $res;
}
//封装好的CURL请求函数,支持POST|GET
public static function send_curl($API_URL, $type, $get_post_data, $sign)
{
$ch = curl_init();
if ($type == 'POST') {
curl_setopt($ch, CURLOPT_URL, $API_URL);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, $get_post_data);
} elseif ($type == 'GET') {
curl_setopt($ch, CURLOPT_URL, $API_URL . '?' . $get_post_data);
}
if ($sign) {
curl_setopt($ch, CURLOPT_HTTPHEADER, ['sign:' . $sign]);
}
curl_setopt($ch, CURLOPT_REFERER, $API_URL);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_TIMEOUT, 10);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
$resdata = curl_exec($ch);
curl_close($ch);
return $resdata;
}
}
//jQuery-Ajax
$.ajax({
url: '',
data: {
//接口参数,一行一个,可按照接口文档-请求参数 的参数填写,或者直接复制开发工具下面的测试代码。
key: '你的接口密钥,登录控制台后在密钥管理页面申请',
参数名: '参数值',
},
type: 'GET', //请求协议(GET或POST),一般默认GET,部分接口需要POST请求,根据实际情况修改为POST即可。
dataType: 'json',
success: function(data) {
console.log(data); //请求成功,输出结果到控制台
},
timeout: 3000, //超时时间
error: function(data) {
console.log('请求失败'); //失败处理
}
});
子程序名 | 返回值类型 | 公开 | 备 注 | ||
__启动窗口_创建完毕 |
子程序名 | 返回值类型 | 公开 | 备 注 | ||
Send_API |
变量名 | 类 型 | 静态 | 数组 | 备 注 | ||
REQU_Data | 文本型 | 提交字符串 | ||||
return | 文本型 | 返回字符串 | ||||
API_URL | 文本型 | 接口地址 | ||||
API_KEY | 文本型 | 接口密钥 |
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
public class Test {
public static void main(String[] args) {
try {
URL url = new URL("?key=你的接口密钥,登录控制台后在密钥管理页面申请");
HttpURLConnection connection = (HttpURLConnection)url.openConnection();
// 设置请求方式
connection.setRequestMethod("GET");
connection.connect();
// 获取响应码
int responseCode = connection.getResponseCode();
if (responseCode == HttpURLConnection.HTTP_OK) {
BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream()));
String line;
while ((line = reader.readLine()) != null) {
// 读取到的内容给line变量
System.out.println(line);
}
reader.close();
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
package main
import (
"fmt"
"io/ioutil"
"net/http"
)
func main() {
// 发起一个GET请求
resp, err := http.Get("?key=你的接口密钥,登录控制台后在密钥管理页面申请")
if err != nil {
fmt.Println("http get error", err)
return
}
// 读取响应结果
result, err := ioutil.ReadAll(resp.Body)
if err != nil {
fmt.Println("http read error", err)
return
}
// 关闭响应结果
defer resp.Body.Close()
fmt.Println(string(result))
}
```
# 导入requests库
import requests
# 设置url
url = '?key=你的接口密钥,登录控制台后在密钥管理页面申请'
# 发送post请求
response = requests.post(url, data={'key1': 'value1', 'key2': 'value2'})
# 获取响应内容
result = response.json()
# 打印结果
print(result)
```
// 以下是使用Node.js进行GET和POST请求API接口的示例代码:
const https = require('https');
const querystring = require('querystring');
// 定义请求选项
const options = {
hostname: 'www.tutengai.com',
path: '/new_test',
method: 'GET'
};
// 发送GET请求
https.get(options, res => {
console.log(`statusCode: ${res.statusCode}`);
res.on('data', d => {
process.stdout.write(d);
});
}).on('error', error => {
console.error(error);
});
// 发送POST请求
const postData = querystring.stringify({
'key1': 'value1',
'key2': 'value2'
});
const postOptions = {
hostname: 'www.tutengai.com',
path: '/new_test',
method: 'POST',
headers: {
'Content-Type': 'application/x-www-form-urlencoded',
'Content-Length': Buffer.byteLength(postData)
}
};
const postReq = https.request(postOptions, res => {
console.log(`statusCode: ${res.statusCode}`);
res.on('data', d => {
process.stdout.write(d);
});
});
postReq.on('error', error => {
console.error(error);
});
postReq.write(postData);
postReq.end();
/*
这个示例代码使用Node.js内置的`https`模块进行HTTP请求。
首先定义了一个GET请求的选项,然后使用`https.get()`方法发送了GET请求。在响应流上注册回调函数,以便在收到响应数据时将其输出到控制台。在出现错误时,也注册了错误处理程序。
类似地,我们也定义了一个POST请求选项,并使用`https.request()`方法发送它。需要在请求头中包含适当的`Content-Type`和`Content-Length`以确保服务器可以正确解析请求体。请求体由`write()`方法写入,并在请求结束时通过调用`end()`方法通知请求对象已经完成。
注意,此示例默认使用`querystring`模块将数据作为x-www-form-urlencoded格式进行编码。如果需要使用其他格式(如JSON),则需要相应地更改请求头和请求体的编码方式。
另外,为了确保HTTPS请求的安全性,您也可以添加其他选项,例如验证服务器证书、设置代理等。
*/
以下是使用C语言进行GET和POST请求API接口的示例代码:
``` c
#include
#include
#include
#include // 需要安装curl库
// API地址
const char* url = "";
// GET请求
void getRequest(CURL* curl) {
CURLcode res;
// 设置URL
curl_easy_setopt(curl, CURLOPT_URL, url);
// 执行请求
res = curl_easy_perform(curl);
if(res != CURLE_OK) {
fprintf(stderr, "curl_easy_perform() failed: %s\n", curl_easy_strerror(res));
}
}
// POST请求
void postRequest(CURL* curl) {
CURLcode res;
// 设置URL
curl_easy_setopt(curl, CURLOPT_URL, url);
// 设置POST数据
const char* postData = "key=你的接口密钥,登录控制台后在密钥管理页面申请&key1=value1";
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, postData);
// 执行请求
res = curl_easy_perform(curl);
if(res != CURLE_OK) {
fprintf(stderr, "curl_easy_perform() failed: %s\n", curl_easy_strerror(res));
}
}
int main() {
CURL* curl;
CURLcode res;
// 初始化curl
curl = curl_easy_init();
if(curl) {
// 设置SSL验证
curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 1L);
// GET请求
getRequest(curl);
// POST请求
postRequest(curl);
// 清理curl资源
curl_easy_cleanup(curl);
}
return 0;
}
```
这个示例代码使用了libcurl库进行HTTP请求。
首先,需要设置API地址。然后,基于`CURL`结构体创建curl句柄,并使用`curl_easy_setopt()`函数设置选项。这里设置了SSL验证,以确保请求的安全性。
在GET请求中,只需将URL设置为选项,然后调用`curl_easy_perform()`函数执行请求即可。
在POST请求中,还需要将POST数据作为字符串传递给`CURLOPT_POSTFIELDS`选项。
需要注意的是,为了避免内存泄漏,应该在使用完curl句柄之后调用`curl_easy_cleanup()`函数进行清理。
除了上述示例代码外,libcurl库还提供了更多高级选项,例如处理HTTP头、上传文件等。可以参考文档进行更详细的了解。
以下是一个使用C++请求API接口的示例代码:
```cpp
#include
#include
int main() {
CURL *curl;
CURLcode res;
std::string url = "?key=你的接口密钥,登录控制台后在密钥管理页面申请";
std::string response;
curl = curl_easy_init();
if (curl) {
curl_easy_setopt(curl, CURLOPT_URL, url.c_str());
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1L);
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, [](char *ptr, size_t size, size_t nmemb, void *userdata) -> size_t {
std::string *response = reinterpret_cast(userdata);
response->append(ptr, size * nmemb);
return size * nmemb;
});
curl_easy_setopt(curl, CURLOPT_WRITEDATA, &response);
res = curl_easy_perform(curl);
if (res == CURLE_OK) {
std::cout << "Response: " << response << std::endl;
} else {
std::cerr << "Error: " << curl_easy_strerror(res) << std::endl;
}
curl_easy_cleanup(curl);
}
return 0;
}
```
解释:
1. 引入需要的头文件:``用于输出结果,``用于使用libcurl库。
2. 定义需要请求的API接口的URL和存储响应数据的字符串变量。
3. 初始化一个CURL对象。
4. 设置CURL对象的参数:请求的URL(`CURLOPT_URL`)、是否跟随重定向(`CURLOPT_FOLLOWLOCATION`)、响应数据的写入函数(`CURLOPT_WRITEFUNCTION`)和响应数据的写入位置(`CURLOPT_WRITEDATA`)。
5. 发送HTTP请求并获取响应数据,判断返回状态码是否OK。
6. 清理CURL对象。
运行该程序会发送GET请求到指定的API接口URL,并在程序终止前将响应数据输出到终端。注意,在使用该示例代码之前需要安装libcurl库。
以下是一个使用C#请求API接口的示例代码:
```csharp
using System;
using System.Net.Http;
using System.Threading.Tasks;
class Program {
static async Task Main(string[] args) {
HttpClient client = new HttpClient();
string url = "?key=你的接口密钥,登录控制台后在密钥管理页面申请";
HttpResponseMessage response = await client.GetAsync(url);
if (response.IsSuccessStatusCode) {
string responseBody = await response.Content.ReadAsStringAsync();
Console.WriteLine("Response: " + responseBody);
} else {
Console.WriteLine("Error: " + response.StatusCode);
}
}
}
```
解释:
1. 引用需要的命名空间:`System.Net.Http`用于使用HttpClient类,`System.Threading.Tasks`用于异步执行请求操作。
2. 创建一个HttpClient对象。
3. 定义需要请求的API接口的URL。
4. 发送GET请求到指定的API接口URL,并获取响应结果。
5. 判断响应状态是否成功,如果成功则读取响应数据(使用ReadAsStringAsync方法),否则输出错误信息(使用StatusCode属性)。
运行该程序会发送GET请求到指定的API接口URL,并在程序终止前将响应数据输出到终端。注意,在使用该示例代码之前需要安装.NET Framework或.NET Core SDK。
以下是VB请求API接口的示例代码:
```
' 1. 引入Microsoft XML v6.0库
' 2. 创建一个XMLHTTP对象
Dim xhr As XMLHTTP
Set xhr = New XMLHTTP
' 3. 设置请求的URL、方法,以及是否异步等
xhr.Open "GET", "?key=你的接口密钥,登录控制台后在密钥管理页面申请", False
' 4. 发送请求
xhr.send
' 5. 获取响应结果
Dim responseText As String
responseText = xhr.responseText
' 6. 输出响应结果
Debug.Print responseText
' 7. 释放资源
Set xhr = Nothing
```
在这个示例中,我们创建了一个XMLHTTP对象,用于请求API接口。我们先调用`open`方法来设置请求的URL、方法,以及是否异步。然后,我们发送请求,并使用`responseText`属性来获取响应结果。最后,我们将响应结果打印到控制台,完成操作后释放资源,以防止内存泄漏。请注意,以上示例代码为同步请求,如果想使用异步请求,需要设置第三个参数为`True`,并在请求结束时处理`OnReadyStateChange`事件。
请 登录 后发表评论
填写业务相关参数免费在线调试
生成符合你的开发语言代码,复制即可
调整你后端部分逻辑代码即可上线使用