和室友參加的互聯(lián)網(wǎng)大賽要做一個(gè) APP酵紫,涉及到用戶的登錄注冊,于是上網(wǎng)找了許多資料赏殃,其中有阿里大于,網(wǎng)易云等等间涵,阿里大于的客服給我說他們不支持 Android仁热,網(wǎng)易云還要拍手持身份證的照片,而且這兩個(gè)都收費(fèi)勾哩,還麻煩抗蠢,于是找了一個(gè)既簡單有免費(fèi)的举哟,叫做 Mob,官網(wǎng)如下
官方文檔看了很多迅矛,還是覺得寫的不好妨猩,于是自己寫一篇。
注冊賬號
在 Mob 官網(wǎng)右上角點(diǎn)擊注冊秽褒,依次填入信息壶硅,其中公司一欄可以隨便填
添加應(yīng)用
登錄后,點(diǎn)擊 SecurityCodeSDK - 立即使用销斟,Mob 會(huì)提示你添加應(yīng)用庐椒,名字自己填,再選 Android票堵,添加完后再點(diǎn)擊 SecurityCodeSDk - 進(jìn)入扼睬,之后應(yīng)該可以看到如下界面
AppKey 和 AppSecret 一會(huì)會(huì)用到
下載 SDK
在網(wǎng)頁上方“下載SDK”中點(diǎn)擊“免費(fèi)短信驗(yàn)證碼SDK”,網(wǎng)頁跳轉(zhuǎn)后找到“短信驗(yàn)證碼SDK”悴势,根據(jù)需要選擇系統(tǒng)吧窗宇,我做的 Android 就選 Android,網(wǎng)頁跳轉(zhuǎn)后根據(jù)需要選擇 AndroidStudio 或者 eclipse特纤,在屏幕右方選擇军俊,選好后點(diǎn)擊即可開始下載。
下好后解壓捧存,打開文件夾粪躬,目錄結(jié)構(gòu)如下
要用到的 SDK 在 SMSSDK 文件夾中
導(dǎo)入 SDK 到工程目錄
打開 SMSSDK 文件夾,把兩個(gè) .jar 和 .aar 文件復(fù)制到工程目錄中 libs 文件夾下昔穴,如圖所示
粘貼進(jìn)去后镰官,選中兩個(gè) .jar 文件,右鍵點(diǎn)擊吗货,選擇 add as library
再打開 app 目錄下的 build.gradle泳唠,添加如下兩處內(nèi)容
repositories{
flatDir{
dirs 'libs'
}
}
compile name:'SMSSDK-2.1.4',ext:'aar'
compile name:'SMSSDKGUI-2.1.4',ext:'aar'
最后看起來是這樣的
添加的代碼為 22-26 行和 36-37 行。
打開 AndroidManifest.xml宙搬,添加如下權(quán)限
<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.RECEIVE_SMS" />
<uses-permission android:name="android.permission.READ_SMS" />
<uses-permission android:name="android.permission.GET_TASKS" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
程序代碼
先把完整代碼貼出來(沒貼 xml笨腥,這個(gè)不影響)
public class Register extends AppCompatActivity implements View.OnClickListener {
private EditText etPhoneNumber; // 電話號碼
private Button sendVerificationCode; // 發(fā)送驗(yàn)證碼
private EditText etVerificationCode; // 驗(yàn)證碼
private Button nextStep; // 下一步
private String phoneNumber; // 電話號碼
private String verificationCode; // 驗(yàn)證碼
private boolean flag; // 操作是否成功
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_register);
init(); // 初始化控件、注冊點(diǎn)擊事件
final Context context = Register.this; // context
final String AppKey = "你的 AppKey"; // AppKey
final String AppSecret = "你的 AppSecret"; // AppSecret
SMSSDK.initSDK(context, AppKey, AppSecret); // 初始化 SDK 單例勇垛,可以多次調(diào)用
EventHandler eventHandler = new EventHandler(){ // 操作回調(diào)
@Override
public void afterEvent(int event, int result, Object data) {
Message msg = new Message();
msg.arg1 = event;
msg.arg2 = result;
msg.obj = data;
handler.sendMessage(msg);
}
};
SMSSDK.registerEventHandler(eventHandler); // 注冊回調(diào)接口
}
private void init() {
etPhoneNumber = (EditText) findViewById(R.id.edit_phone_number);
sendVerificationCode = (Button) findViewById(R.id.btn_send_verification_code);
etVerificationCode = (EditText) findViewById(R.id.edit_verification_code);
nextStep = (Button) findViewById(R.id.btn_next_step);
sendVerificationCode.setOnClickListener(this);
nextStep.setOnClickListener(this);
}
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.btn_send_verification_code:
if (!TextUtils.isEmpty(etPhoneNumber.getText())) {
if (etPhoneNumber.getText().length() == 11) {
phoneNumber = etPhoneNumber.getText().toString();
SMSSDK.getVerificationCode("86", phoneNumber); // 發(fā)送驗(yàn)證碼給號碼的 phoneNumber 的手機(jī)
etVerificationCode.requestFocus();
}
else {
Toast.makeText(this, "請輸入完整的電話號碼", Toast.LENGTH_SHORT).show();
etPhoneNumber.requestFocus();
}
} else {
Toast.makeText(this, "請輸入電話號碼", Toast.LENGTH_SHORT).show();
etPhoneNumber.requestFocus();
}
break;
case R.id.btn_next_step:
if (!TextUtils.isEmpty(etVerificationCode.getText())) {
if (etVerificationCode.getText().length() == 4) {
verificationCode = etVerificationCode.getText().toString();
SMSSDK.submitVerificationCode("86", phoneNumber, verificationCode);
flag = false;
} else {
Toast.makeText(this, "請輸入完整的驗(yàn)證碼", Toast.LENGTH_SHORT).show();
etVerificationCode.requestFocus();
}
} else {
Toast.makeText(this, "請輸入驗(yàn)證碼", Toast.LENGTH_SHORT).show();
etVerificationCode.requestFocus();
}
break;
default:
break;
}
}
Handler handler = new Handler() {
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
int event = msg.arg1;
int result = msg.arg2;
Object data = msg.obj;
if (result == SMSSDK.RESULT_COMPLETE) {
// 如果操作成功
if (event == SMSSDK.EVENT_SUBMIT_VERIFICATION_CODE) {
// 校驗(yàn)驗(yàn)證碼脖母,返回校驗(yàn)的手機(jī)和國家代碼
Toast.makeText(Register.this, "驗(yàn)證成功", Toast.LENGTH_SHORT).show();
Intent intent = new Intent(Register.this, MainActivity.class);
startActivity(intent);
} else if (event == SMSSDK.EVENT_GET_VERIFICATION_CODE) {
// 獲取驗(yàn)證碼成功,true為智能驗(yàn)證闲孤,false為普通下發(fā)短信
Toast.makeText(Register.this, "驗(yàn)證碼已發(fā)送", Toast.LENGTH_SHORT).show();
} else if (event == SMSSDK.EVENT_GET_SUPPORTED_COUNTRIES) {
// 返回支持發(fā)送驗(yàn)證碼的國家列表
}
} else {
// 如果操作失敗
if (flag) {
Toast.makeText(Register.this, "驗(yàn)證碼獲取失敗谆级,請重新獲取", Toast.LENGTH_SHORT).show();
etPhoneNumber.requestFocus();
} else {
((Throwable) data).printStackTrace();
Toast.makeText(Register.this, "驗(yàn)證碼錯(cuò)誤", Toast.LENGTH_SHORT).show();
}
}
}
};
@Override
protected void onDestroy() {
super.onDestroy();
SMSSDK.unregisterAllEventHandler(); // 注銷回調(diào)接口
}
}
注意要把你的 AppKey 和 AppSecret 替換進(jìn)去。
其實(shí)看過很多教程你會(huì)發(fā)現(xiàn),很多時(shí)候并不是代碼看不懂哨苛,而是在配置文件的時(shí)候出了問題鸽凶,因?yàn)橐粋€(gè)剛接觸 Android 沒兩天的人是不可能對很多第三方 SDK 有需求的,一開始都是以基礎(chǔ)為主建峭,所以需要配置第三方 SDK 的很多都是寫過一些 Android 代碼的人玻侥,他們所關(guān)心的其實(shí)就是該調(diào)用哪些方法來實(shí)現(xiàn)自己的目的,所以知道怎么調(diào)用就行了亿蒸,再根據(jù)實(shí)際需求寫幾個(gè) if-else 就可以了凑兰。
注意
SMSSDK.initSDK(context, AppKey, AppSecret); // 初始化 SDK 單例,可以多次調(diào)用
EventHandler eventHandler = new EventHandler(){ // 操作回調(diào)
@Override
public void afterEvent(int event, int result, Object data) {
Message msg = new Message();
msg.arg1 = event;
msg.arg2 = result;
msg.obj = data;
handler.sendMessage(msg);
}
};
SMSSDK.registerEventHandler(eventHandler); // 注冊回調(diào)接口
這幾行代碼是調(diào)用這個(gè) SDK 的基礎(chǔ)边锁,寫在 onCreate 中姑食。
發(fā)送短信驗(yàn)證碼的語句是
`SMSSDK.getVerificationCode("86", phoneNumber);`
phoneNumber 的取值取決于用戶輸入的號碼,“86”是中國的區(qū)號茅坛,根據(jù)需求也可以讓用戶自己選擇音半,稍微修改一下就行。
>```
if (result == SMSSDK.RESULT_COMPLETE) {
// 如果操作成功
if (event == SMSSDK.EVENT_SUBMIT_VERIFICATION_CODE) {
// 校驗(yàn)驗(yàn)證碼贡蓖,返回校驗(yàn)的手機(jī)和國家代碼
Toast.makeText(Register.this, "驗(yàn)證成功", Toast.LENGTH_SHORT).show();
Intent intent = new Intent(Register.this, MainActivity.class);
startActivity(intent);
} else if (event == SMSSDK.EVENT_GET_VERIFICATION_CODE) {
// 獲取驗(yàn)證碼成功曹鸠,true為智能驗(yàn)證,false為普通下發(fā)短信
Toast.makeText(Register.this, "驗(yàn)證碼已發(fā)送", Toast.LENGTH_SHORT).show();
} else if (event == SMSSDK.EVENT_GET_SUPPORTED_COUNTRIES) {
// 返回支持發(fā)送驗(yàn)證碼的國家列表
}
} else {
// 如果操作失敗
if (flag) {
Toast.makeText(Register.this, "驗(yàn)證碼獲取失敗斥铺,請重新獲取", Toast.LENGTH_SHORT).show();
etPhoneNumber.requestFocus();
} else {
((Throwable) data).printStackTrace();
Toast.makeText(Register.this, "驗(yàn)證碼錯(cuò)誤", Toast.LENGTH_SHORT).show();
}
}
這幾行代碼判斷驗(yàn)證碼發(fā)沒發(fā)送以及正不正確彻桃,根據(jù) event 來確定是哪一種情況,如果想深入了解晾蜘,可以參考官方文檔
當(dāng)然邻眷,免費(fèi)服務(wù)肯定收費(fèi)的要差點(diǎn),體現(xiàn)在短信發(fā)的比收費(fèi)的慢剔交,大概要十秒才能收到肆饶,收費(fèi)的三秒就收到了,由于只是個(gè)比賽岖常,自己做著玩抖拴,用免費(fèi)的足矣。
另外腥椒,最開始免費(fèi)的時(shí)候每天只能發(fā) 20 條短信,而且一個(gè)手機(jī)號每 12 小時(shí)只能收到 5 條候衍,所以笼蛛,省著點(diǎn)用,當(dāng)然你可以在應(yīng)用管理界面申請上線登記(見第一張圖)蛉鹿,審核通過后就完全免費(fèi)了滨砍。