驗(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)品報價
CNN:15狀態(tài)碼原因分析:余額不足CNN:15錯誤碼歸屬:平臺CNN:15返回值解決方案:短信接口返回值為CNN:15時,導(dǎo)致用戶無法正常接收短信,對公司的業(yè)務(wù)正常開展造成不利影響。針對短信接口錯誤碼為CNN:15問題...
DIGIT_BUSI狀態(tài)碼原因分析:業(yè)務(wù)校驗(yàn)失敗DIGIT_BUSI錯誤碼歸屬:平臺DIGIT_BUSI返回值解決方案:短信接口返回值為DIGIT_BUSI時,導(dǎo)致用戶無法正常接收短信,對公司的業(yè)務(wù)正常開展造成不利影響。...
政務(wù)信息的公開化使政府與群眾間架起一座連心橋。短信是政務(wù)信息發(fā)布重要渠道之一。政務(wù)短信平臺除了將消息傳遞給公民,同時也適用于政府對企業(yè)(如稅務(wù)提醒、政策通知)、政府內(nèi)部(如會議通知、薪資發(fā)放)等場景。政務(wù)短信平臺,有效提...
R:00096狀態(tài)碼原因分析:關(guān)機(jī)R:00096錯誤碼歸屬:聯(lián)通R:00096返回值解決方案:短信接口返回值為R:00096時,導(dǎo)致用戶無法正常接收短信,對公司的業(yè)務(wù)正常開展造成不利影響。針對短信接口錯誤碼為R:0009...
政務(wù)短信平臺已經(jīng)廣泛應(yīng)用于各級政府機(jī)關(guān),尤其對于緊急事件的公布,政務(wù)短信的作用尤為重要。政務(wù)短信平臺將防汛預(yù)警、疾病防治知識傳遞給公民,同時也適用于政府對企業(yè)(如稅務(wù)提醒、政策通知)、政府內(nèi)部(如會議通知、指示傳達(dá))等場...
語音通知接口即語音通知發(fā)送API接口,面向有一定技術(shù)開發(fā)能力的企業(yè)。語音通知接口支持二次開發(fā),可把語音通知接口嵌入到企業(yè)自有的網(wǎng)站、APP及業(yè)務(wù)系統(tǒng)中,快速擁有語音通知發(fā)送能力。語音通知接口一般支持http、https和webservice調(diào)用,HTTPService基于http協(xié)議,而WebService基于soap協(xié)議。如需使用asp開發(fā)語音通知接口服務(wù),需先在第三方短信平臺開通短信賬號,獲取語音通知接口地址及相關(guān)請求參數(shù),如發(fā)送至手機(jī)號碼、發(fā)送的短信內(nèi)容及其他相關(guān)參數(shù),成功調(diào)用后會返回XML數(shù)據(jù),提示短信提交成功和失敗。
asp語音通知的應(yīng)用場景非常廣泛,三大運(yùn)營商特有的身份認(rèn)證能力能夠有效確保用戶信息的準(zhǔn)確性,因此語音通知也被應(yīng)用在登錄、注冊、支付等高頻次場景中,此外,會員通知也是很常見的短信應(yīng)用場景之一,企業(yè)向自己的會員發(fā)送語音通知,將重要通知以語音形式播報,可以有效避免用戶遺漏重要信息,有效減少了物流企業(yè)的售后成本,優(yōu)化了用戶服務(wù)體驗(yàn)。
在IT、化工、建材、能源、房產(chǎn)、工商等多個領(lǐng)域,語音通知都具有難以替代的作用,其在身份驗(yàn)證、及時觸達(dá)領(lǐng)域有著其他產(chǎn)品所不具備的能力,是現(xiàn)代企業(yè)安全體系中不可或缺的一環(huán)。
語音驗(yàn)證碼的出現(xiàn)極大地簡化了用戶注冊登陸的流程,再過去,用戶注冊一個賬號往往需要填寫非常繁瑣的資料,這往往會花費(fèi)用戶十多分鐘的時間,但現(xiàn)在,用戶注冊賬號通常只需要一個驗(yàn)證碼,以往需要實(shí)際分鐘才能完成的認(rèn)證步驟現(xiàn)在只需要幾十秒,短信基于三大運(yùn)營商的身份認(rèn)證能力可以確保信息的安全正確,在確保安全等級沒有降低的情況下,大大優(yōu)化了注冊登陸的流程,深受企業(yè)及用戶的喜愛。
企業(yè)用戶對接短信流程非常簡單,過程順暢的話通常半個小時即可對接完成,在進(jìn)行技術(shù)對接之前,用戶需先注冊短信平臺賬號,領(lǐng)取測試短信,隨后即可進(jìn)行技術(shù)對接,互億無線提供完善的asp短信接口,如有疑問,也可尋求免費(fèi)的技術(shù)支持,接入服務(wù)測試跑通之后,用戶只需完成企業(yè)注冊,充值賬戶即可正式上線服務(wù)。
目前主流的短信接口標(biāo)準(zhǔn)主要有HTTP、HTTPS、SMPP、CMPP、SMGP、SGIP等,其中最為常用的是HTTP、HTTPS兩種短信接口協(xié)議,HTTP是超文本傳輸協(xié)議,信息是明文傳輸,簡捷快速,允許傳輸任意類型的數(shù)據(jù)對象,同時限制單次鏈接只處理一個請求,節(jié)省傳輸時間,但是HTTP協(xié)議是無狀態(tài)協(xié)議,對事務(wù)處理沒有記憶能力,缺少狀態(tài)必須重傳,這樣可能導(dǎo)致每次連接傳送的數(shù)據(jù)量增大。
如果還有更多關(guān)于asp實(shí)現(xiàn)語音通知功能的問題,請咨詢工作了解詳情,也可進(jìn)入幫助文檔查看相關(guān)內(nèi)容。
互億無線:為了成功發(fā)送一條短信通知,您至少需要完成以下步驟: 1.注冊賬號 2.賬號認(rèn)證 3.短信接口調(diào)試 4.購買短信套餐 5.設(shè)置短信簽名、添加短信模板 6.上線使用...
互億無線:(1)支持固定外呼號碼的申請。 (2)聯(lián)系商務(wù)提交對應(yīng)資料進(jìn)行申請。...
互億無線:支持,wav/mp3格式、小于5M的語音文件,需提供源文件給對接商務(wù)經(jīng)理進(jìn)行報備。...
互億無線:可以,注冊賬戶后,我們將免費(fèi)贈送10條測試短信。您可以對接短信接口進(jìn)行調(diào)試,并進(jìn)行短信測試。...
互億無線:語音通話不支持同時呼叫,但支持多次調(diào)用接口呼叫不同號碼;由于運(yùn)營商管控策略的不同,并發(fā)數(shù)量會存在差異,一般默認(rèn)并發(fā)為10,如果業(yè)務(wù)量較大,可以聯(lián)系商務(wù)經(jīng)理進(jìn)行配置。...