本文檔主要提供給互億平臺的用戶對接接口的使用說明,開發(fā)者可以利用互億無線提供的 Http / Https 接口,調(diào)用互億無線的運營商三要素服務(wù),進行手機號碼核驗。
本文檔包含提交認(rèn)證、余額查詢。
GET / POST
1、采用HTTPS協(xié)議提交請求
2、通過MD5動態(tài)簽名方式加密
登錄用戶中心,進入【實名認(rèn)證】模塊,在【產(chǎn)品總覽】頁面右上角,如下圖所示:
通過POST、 GET 方式進行提交,數(shù)據(jù)編碼采用utf-8格式,支持24小時全天提交。
內(nèi)容格式為:Content-Type: application/x-www-form-urlencoded
https://api.ihuyi.com/idcard/Submit.json
參數(shù)名稱 | 參數(shù)值描述 | 必填 |
account | APIID(用戶中心【實名認(rèn)證】-【產(chǎn)品總覽】查看) | 是 |
password | 1、APIKEY(用戶中心【實名認(rèn)證】-【產(chǎn)品總覽】查看) 2、動態(tài)密碼(生成動態(tài)密碼方式請看該文檔末尾的說明) |
是 |
app | oper3m | 是 |
name | 身份證姓名(md5加密32位小寫) | 是 |
id_card_no | 身份證號碼(md5加密32位小寫) | 是 |
mobile | 手機號碼(md5加密32位小寫) | 是 |
time | Unix時間戳(10位整型數(shù)字,當(dāng)使用動態(tài)密碼方式時為必填) | 否 |
用戶通過http 或 https提交發(fā)送請求到服務(wù)器后,服務(wù)器會返回一串json格式的字符串,SubmitResult結(jié)構(gòu)說明如下:
參數(shù)名稱 | 類型 | 描述 |
code | int | 返回值為2時,表示提交成功 |
idcardid | string | 當(dāng)提交成功后,此字段為流水號,否則為0 |
msg | string | 提交結(jié)果描述 |
result | object | 認(rèn)證結(jié)果 |
result.status | int | 認(rèn)證狀態(tài)(0未認(rèn)證,1認(rèn)證未通過,2認(rèn)證通過) |
result.info | object | 保留字段 |
示例(成功)
{"code":2,"msg":"提交成功","idcardid":"16236437872836","result":{"status":2,"info":{}}}
示例(失?。?/p>
{"code":405,"msg":"API ID或API KEY不正確","idcardid":"0","result":{"status":0,"info":{}}}
code | msg |
0 | 未知錯誤 |
1 | 提交失敗 |
2 | 提交成功 |
400 | 非法ip訪問 |
401 | 帳號不能為空 |
402 | 密碼不能為空 |
403 | 應(yīng)用不存在 |
404 | 姓名不能為空 |
4041 | 姓名格式不正確(32位姓名的md5加密字符串) |
406 | 身份證號碼不能為空 |
4061 | 身份證號碼格式不正確(32位身份證號碼的md5加密字符串) |
407 | 手機號不能為空 |
4071 | 手機號格式不正確(32位手機號的md5加密字符串) |
405 | API ID 或 API KEY 不正確 |
4050 | 賬號被凍結(jié) |
40501 | 動態(tài)密碼已過期 |
40502 | 動態(tài)密碼校驗失敗 |
40505 | 沒有簽定合同 |
4051 | 剩余條數(shù)不足 |
4052 | 訪問 ip 與備案 ip 不符 |
4086 | 通道無效 |
4010 | 通道錯誤 |
https://api.ihuyi.com/idcard/Submit.json&account=APIID&password=APIKEY&app=oper3m&name=姓名&id_card_no=401123343333xxxxxxxxxxxxxx&mobile=手機號
通過接口可以方便的查詢你的賬戶剩余條數(shù)。
內(nèi)容格式為:Content-Type: application/x-www-form-urlencoded
https://api.ihuyi.com/idcard/GetNum.json
參數(shù)名稱 | 參數(shù)值描述 | 是否必填 |
account | APIID(用戶中心【實名認(rèn)證】-【產(chǎn)品總覽】查看) | 是 |
password | 1、APIKEY(用戶中心【實名認(rèn)證】-【產(chǎn)品總覽】查看) 2、動態(tài)密碼(生成動態(tài)密碼方式請看該文檔末尾的說明) |
是 |
app | oper3m | 是 |
time | Unix時間戳(10位整型數(shù)字,當(dāng)使用動態(tài)密碼方式時為必填) | 否 |
用戶通過http 或 https提交請求到服務(wù)器后,服務(wù)器會返回一串json格式的字符串,GetNumResult結(jié)構(gòu)說明如下:
參數(shù)名稱 | 類型 | 描述 |
code | int | 狀態(tài)返回值 |
msg | string | 查詢結(jié)果描述 |
num | string | 剩余數(shù)量 |
示例(成功)
{"code":2,"msg":"查詢成功","num":123}
示例(失敗)
{"code":405,"msg":"API ID或API KEY不正確","num":0}
code | msg |
2 | 查詢成功 |
400 | 非法ip訪問 |
401 | 帳號不能為空 |
402 | 密碼不能為空 |
403 | 應(yīng)用不存在 |
405 | API ID或API KEY不正確 |
4050 | 賬號被凍結(jié) |
40501 | 動態(tài)密碼已過期 |
40502 | 動態(tài)密碼校驗失敗 |
4052 | 訪問ip與備案ip不符 |
https://api.ihuyi.com/idcard/GetNum.json&account=APIID&password=APIKEY&app=oper3m
以PHP為例,提交認(rèn)證的生成方式:
$time = time(); $password=md5($account.$apikey.$app.$name.$id_card_no.$mobile.$time);
例如:
APIID: test APIKEY:1q784322b****** app:oper3m name:張三 id_card_no:401221****** mobile:13600000000 time:1651544941 結(jié)果:$password=md5("test1q784322b******oper3m張三401221******136000000001651544941");
注意:所有字符編碼統(tǒng)一為UTF-8
查詢剩余條數(shù)的生成方式:
$time = time(); $password=md5($account.$apikey.$app.$time);
例如:
APIID: test APIKEY:1q784322ba1****** app:oper3m time:1651544941 結(jié)果:$password=md5("test1q784322ba1******oper3m1651544941");
Unix時間戳參考地址:http://tool.chinaz.com/Tools/unixtime.aspx
語言 | 代碼 |
JAVA | String date = new java.text.SimpleDateFormat("dd/MM/yyyy HH:mm:ss").format(new java.util.Date(Unix timestamp *1000)) |
Linux | date -d @Unix timestamp |
C | strptime(datetime, "%Y-%m-%d %H:%M:%S", &tm_time); unixtime = mktime(&tm_time); |
C++ | std::time_t t = std::time(0); |
DELPHI | uses DateUtils; DateTimeToUnix(Now) |
GO | import "time" cur := time.Now() timestamp := cur.UnixNano() / 1000000 |
Perl | 先 my $time = Unix timestamp 然后 my ($sec, $min, $hour, $day, $month, $year) = (localtime($time))[0,1,2,3,4,5,6] |
PHP | date("r", Unix timestamp) |
Node.js | var date = new Date( time * 1000 ); var time = date.getTime()/1000; |
Python | 先 import time 然后 time.gmtime(Unix timestamp) |
Ruby | Time.at(Unix timestamp) |
SHELL | date +%s //UNIX 的時間戳; |
VBScript / ASP | DateAdd("s", Unix timestamp, "01/01/1970 00:00:00") |
VB6 | DateDiff("s", "1970-1-1 0:0:0", ToUnixTime) |
易語言 | 時間_到時間戳() |
自助開通運營商三要素認(rèn)證MD5加密版接口
驗證姓名、身份證號、手機號是否一致
運營商三要素套餐 免費開通賬戶 運營商三要素介紹
驗證碼已發(fā)送到您的手機,請查收!
輸入驗證碼后,點擊“開通體驗賬戶”按鈕可立即開通體驗賬戶。