驗(yàn)證碼短信
5秒達(dá)、99%到達(dá)率
適用于用戶注冊、會員登錄等場景
PHP代碼示例
//接口類型:互億無線語音驗(yàn)證碼接口。
//賬戶注冊:請通過該地址開通賬戶http://user.ihuyi.com/register.html
//注意事項(xiàng):
//(1)調(diào)試期間,請仔細(xì)閱讀接口文檔;
//(2)請使用 APIID 及 APIKEY來調(diào)用接口,可在會員中心獲??;
//(3)該代碼僅供接入互億無線短信接口參考使用,客戶可根據(jù)實(shí)際需要自行編寫;
header("Content-type:text/html; charset=UTF-8");
function Post($curlPost,$url){
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_HEADER, false);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
curl_setopt($curl, CURLOPT_NOBODY, true);
curl_setopt($curl, CURLOPT_POST, true);
curl_setopt($curl, CURLOPT_POSTFIELDS, $curlPost);
$return_str = curl_exec($curl);
curl_close($curl);
return $return_str;
}
function xml_to_array($xml){
$reg = "/<(\w+)[^-->]*>([\\x00-\\xFF]*)<\\/\\1>/";
if(preg_match_all($reg, $xml, $matches)){
$count = count($matches[0]);
for($i = 0; $i < $count; $i++){
$subxml= $matches[2][$i];
$key = $matches[1][$i];
if(preg_match( $reg, $subxml )){
$arr[$key] = xml_to_array( $subxml );
}else{
$arr[$key] = $subxml;
}
}
}
return $arr;
}
$target = "http://api.voice.ihuyi.com/webservice/voice.php?method=Submit";
$mobile = '136xxxxxxxx';//手機(jī)號碼
$post_data = "account=用戶名&password=密碼&mobile=".$mobile."&content=1125";
//查看用戶名 登錄用戶中心->語音驗(yàn)證碼>產(chǎn)品總覽->API接口信息->APIID
//查看密碼 登錄用戶中心->語音驗(yàn)證碼>產(chǎn)品總覽->API接口信息->APIKEY
$gets = xml_to_array(Post($post_data, $target));
if($gets['SubmitResult']['code']==2){
echo '提交成功';
}
JAVA代碼示例
import java.io.IOException;
import org.apache.commons.httpclient.HttpClient;
import org.apache.commons.httpclient.HttpException;
import org.apache.commons.httpclient.NameValuePair;
import org.apache.commons.httpclient.methods.PostMethod;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import util.StringUtil;
//接口類型:互億無線語音驗(yàn)證碼接口。
//賬戶注冊:請通過該地址開通賬戶http://user.ihuyi.com/register.html
//注意事項(xiàng):
//(1)調(diào)試期間,請仔細(xì)閱讀接口文檔;
//(2)請使用 APIID 及 APIKEY來調(diào)用接口,可在會員中心獲取;
//(3)該代碼僅供接入互億無線短信接口參考使用,客戶可根據(jù)實(shí)際需要自行編寫;
public class sendsms {
private static String Url = "http://api.voice.ihuyi.com/webservice/voice.php?method=Submit";
public static void main(String [] args) {
HttpClient client = new HttpClient();
PostMethod method = new PostMethod(Url);
//client.getParams().setContentCharset("GBK");
client.getParams().setContentCharset("UTF-8");
method.setRequestHeader("ContentType","application/x-www-form-urlencoded;charset=UTF-8");
NameValuePair[] data = {//提交短信
new NameValuePair("account", "用戶名"),//查看用戶名 登錄用戶中心->語音驗(yàn)證碼>產(chǎn)品總覽->API接口信息->APIID
new NameValuePair("password", "密碼"),//查看密碼 登錄用戶中心->語音驗(yàn)證碼>產(chǎn)品總覽->API接口信息->APIKEY
new NameValuePair("mobile", "139xxxxxxxx"),//手機(jī)號碼
new NameValuePair("content", "1125"),
};
method.setRequestBody(data);
try {
client.executeMethod(method);
String SubmitResult = method.getResponseBodyAsString();
//System.out.println(SubmitResult);
Document doc = DocumentHelper.parseText(SubmitResult);
Element root = doc.getRootElement();
String code = root.elementText("code");
String msg = root.elementText("msg");
String voiceid = root.elementText("voiceid");
System.out.println(code);
System.out.println(msg);
System.out.println(voiceid);
if("2".equals(code)){
System.out.println("短信提交成功");
}
} catch (HttpException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (DocumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
通過POST、 GET 方式進(jìn)行短信提交,數(shù)據(jù)編碼采用utf-8格式,24小時全天發(fā)送。
http://api.voice.ihuyi.com/webservice/voice.php?method=Submit
| 參數(shù)名稱 | 參數(shù)值描述 | 必填 |
| account | APIID(請登錄用戶中心【語音驗(yàn)證碼】-【產(chǎn)品縱覽】查看) | 是 |
| password | 1、APIKEY(請登錄用戶中心【語音驗(yàn)證碼】-【產(chǎn)品縱覽】查看) 2、動態(tài)密碼(生成動態(tài)密碼方式請看該文檔末尾的說明) |
是 |
| mobile | 接收手機(jī)號碼,只能提交1個號碼 | 是 |
| content | 驗(yàn)證碼(4-6位數(shù)字) | 是 |
| time | Unix時間戳(10位整型數(shù)字,當(dāng)使用動態(tài)密碼方式時為必填) | 否 |
| format | 返回格式(可選值為:xml或json,系統(tǒng)默認(rèn)為xml) | 否 |
用戶通過http 或 https提交發(fā)送短信請求到服務(wù)器后,服務(wù)器會返回一串xml格式的字符串,SubmitResult結(jié)構(gòu)說明如下:
| 參數(shù)名稱 | 類型 | 描述 |
| code | int | 返回值為2時,表示提交成功 |
| smsid | string | 當(dāng)提交成功后,此字段為流水號,否則為0 |
| msg | string | 提交結(jié)果描述 |
示例(成功)
2提交成功 60495654
示例(失?。?/p>
405用戶名或密碼不正確 0
| code | msg |
| 0 | 提交失敗 |
| 2 | 提交成功 |
| 400 | 非法ip訪問 |
| 401 | 帳號不能為空 |
| 402 | 密碼不能為空 |
| 403 | 手機(jī)號碼不能為空 |
| 4030 | 手機(jī)號碼已被列入黑名單 |
| 404 | 語音內(nèi)容不能為空 |
| 405 | 用戶名或密碼不正確 |
| 4050 | 賬號被凍結(jié) |
| 4051 | 剩余條數(shù)不足 |
| 4052 | 訪問ip與備案ip不符 |
| 406 | 手機(jī)格式不正確 |
| 407 | 短信內(nèi)容含有敏感字符 |
| 4070 | 語音驗(yàn)證碼內(nèi)容必須為4-6位數(shù)字 |
| 408 | 您的帳戶疑被惡意利用,已被自動凍結(jié),如有疑問請與客服聯(lián)系。 |
http://api.voice.ihuyi.com/webservice/voice.php?method=Submit&account=APIID&password=APIKEY&mobile=手機(jī)號碼&content=1125
| code | msg |
| 0 | 提交失敗 |
| 2 | 提交成功 |
| 400 | 非法ip訪問 |
| 401 | 帳號不能為空 |
| 402 | 密碼不能為空 |
| 403 | 手機(jī)號碼不能為空 |
| 4030 | 手機(jī)號碼已被列入黑名單 |
| 404 | 語音內(nèi)容不能為空 |
| 405 | 用戶名或密碼不正確 |
| 4050 | 賬號被凍結(jié) |
| 4051 | 剩余條數(shù)不足 |
| 4052 | 訪問ip與備案ip不符 |
| 406 | 手機(jī)格式不正確 |
| 407 | 短信內(nèi)容含有敏感字符 |
| 4070 | 語音驗(yàn)證碼內(nèi)容必須為4-6位數(shù)字 |
| 408 | 您的帳戶疑被惡意利用,已被自動凍結(jié),如有疑問請與客服聯(lián)系。 |
| code | msg |
| 2 | 查詢成功 |
| 400 | 非法ip訪問 |
| 401 | 帳號不能為空 |
| 402 | 密碼不能為空 |
| 405 | 用戶名或密碼不正確 |
| 4050 | 賬號被凍結(jié) |
自助開通云通信賬戶
免費(fèi)試用,試用滿意再購買
免費(fèi)開通 產(chǎn)品詳情 查看語音產(chǎn)品報(bào)價
619狀態(tài)碼原因分析:用戶欠費(fèi)停機(jī)619錯誤碼歸屬:電信619返回值解決方案:短信接口返回值為619時,導(dǎo)致用戶無法正常接收短信,對公司的業(yè)務(wù)正常開展造成不利影響。針對短信接口錯誤碼為619問題,互億無線提供完整解決方案...
公共場所提供無線wifi上網(wǎng)服務(wù),需對用戶進(jìn)行實(shí)名認(rèn)證。手機(jī)短信實(shí)名認(rèn)證以其用戶體驗(yàn)、綜合成本等優(yōu)勢,成為公共wifi上網(wǎng)認(rèn)證的首選方案。 一、連接WIFI需要短信驗(yàn)證怎么設(shè)置 公共場所要實(shí)現(xiàn)訪客無線上網(wǎng)短信認(rèn)證...
語音通知作為一種消息推送的方式,在現(xiàn)在很多產(chǎn)品中也有實(shí)際的應(yīng)用。語音通知能力常用于系統(tǒng)告警通知、入住提醒、民生公告報(bào)警等場景中。語音通知能力的優(yōu)勢:向多個用戶發(fā)起批量的快遞送達(dá)通知,大大縮短等待時間;避免用戶收到短信通知...
在當(dāng)今的數(shù)字化環(huán)境中,短信接口的集成對于資產(chǎn)管理系統(tǒng)(AMS)來說至關(guān)重要。它不僅提高了用戶的參與度,還促進(jìn)了信息的高效傳遞。本文將指導(dǎo)您如何將AMS資產(chǎn)管理系統(tǒng)與互億無線短信接口無縫對接。 AMS資產(chǎn)管理系統(tǒng)概述 資...
YX:8018狀態(tài)碼原因分析:內(nèi)容為空YX:8018錯誤碼歸屬:平臺YX:8018返回值解決方案:短信接口返回值為YX:8018時,導(dǎo)致用戶無法正常接收短信,對公司的業(yè)務(wù)正常開展造成不利影響。針對短信接口錯誤碼為YX:8...
語音驗(yàn)證碼接口一般采用http和webservice方式進(jìn)行調(diào)用。使用語音驗(yàn)證碼http接口的效率比較高一些,它支持客戶/服務(wù)器模式,運(yùn)行速度很快,而webservice遇到一些比較復(fù)雜麻煩的數(shù)據(jù)類型時,處理起來更加有效。短信平臺通常會將語音驗(yàn)證碼能力進(jìn)行API封裝,開發(fā)者僅需拷貝幾行代碼,即可在網(wǎng)站、APP、系統(tǒng)中輕松實(shí)現(xiàn)語音驗(yàn)證碼、語音通知等短信內(nèi)容的自動化發(fā)送。開發(fā)者用戶可以通過不同開發(fā)語言,如node.js進(jìn)行語音驗(yàn)證碼接口開發(fā)。一般短信平臺提供的語音驗(yàn)證碼發(fā)送服務(wù),可支持全國移動、聯(lián)通、電信手機(jī)號碼,免除運(yùn)營商之間不同通訊協(xié)議的煩惱。為了更方便開發(fā)者進(jìn)行語音驗(yàn)證碼接入,短信平臺會預(yù)先為開發(fā)者提供各語言的DEMO示例供開發(fā)者使用,僅需少量代碼即可創(chuàng)建語音驗(yàn)證碼API請求。
語音驗(yàn)證碼具備運(yùn)營商特有的身份認(rèn)證能力,企業(yè)通過接入node.js短信接口發(fā)送語音驗(yàn)證碼,及時有效地確認(rèn)用戶身份安全,保障用戶的賬號安全,優(yōu)化企業(yè)的服務(wù)體驗(yàn),語音通知則是企業(yè)維護(hù)會員最常見的方式之一,通常具備功能性,例如系統(tǒng)通知、物流通知等,相較于新生的微信通知等方式,語音通知的觸達(dá)率更高,更及時,也更不容易被用戶所遺漏。
在IT、化工、建材、能源、房產(chǎn)、工商等多個領(lǐng)域,語音驗(yàn)證碼都具有難以替代的作用,其在身份驗(yàn)證、及時觸達(dá)領(lǐng)域有著其他產(chǎn)品所不具備的能力,是現(xiàn)代企業(yè)安全體系中不可或缺的一環(huán)。
語音驗(yàn)證碼具有下發(fā)速度快、觸達(dá)更精準(zhǔn)、接入更靈活的特點(diǎn),通常來說,用戶從獲取驗(yàn)證碼到驗(yàn)證碼下發(fā),這中間的過程不會超過5秒鐘,避免用戶因?yàn)榈却斐傻牧魇?,同時,語音驗(yàn)證碼高達(dá)99.99%的觸達(dá)率也讓信息遺漏的可能性降到了最低。
node.js短信接口接入流程大致分為四步:注冊、測試、認(rèn)證、充值、正式接入。語音驗(yàn)證碼支持測試使用,用戶只需注冊登陸,即可領(lǐng)取測試短信條數(shù),完成技術(shù)對接,進(jìn)行短信測試之后,用戶完成企業(yè)認(rèn)證和賬戶充值,服務(wù)即可正式上線。
WebSercive是一種常用的短信接口形式,這種接口的使用形式和HTTP接口有一定的相似性,接入這種服務(wù)的產(chǎn)品可以像調(diào)用函數(shù)一樣,想要集成短信接口服務(wù),普遍需求用戶有自己的產(chǎn)品,同時具有一定的技術(shù)開發(fā)實(shí)力,接入之后,產(chǎn)品可以根據(jù)不同的情況自動發(fā)送短信。
node.js語音驗(yàn)證碼集成的詳細(xì)資訊,可進(jìn)入幫助文檔查看,也可向平臺相關(guān)人員咨詢。
互億無線:可以,注冊后即免費(fèi)贈送10條短信到您的賬戶。有特殊測試需求請聯(lián)系專屬客戶經(jīng)理獲取更多短信測試條數(shù)。...
互億無線:系統(tǒng)播報(bào)2遍,2遍結(jié)束后,會自動停止掛機(jī)。...
互億無線:開通測試賬戶 – 下載短信接口測試 – 簽訂合同、收款 – 賬戶充值 – 設(shè)置簽名/模板 – 正式使用。...
互億無線:為保證全國范圍的接通率,互億無線會自動選擇最優(yōu)線路進(jìn)行呼叫,透傳的主叫號碼也會相應(yīng)變化。...
互億無線:請先查看短信調(diào)用接口時是否出現(xiàn)異常情況,存在異常則表明短信請求并未提交至短信通道; 如短信接口調(diào)用正常,客戶未收到短信,可能與客戶終端手機(jī)、所處網(wǎng)絡(luò)等有關(guān),可以提供短信下發(fā)的號碼、時間至互億無線售后團(tuán)隊(duì)協(xié)助排查原因。...