当前位置: 首页 > news >正文

哪建网站好网站网站设计的公司

哪建网站好,网站网站设计的公司,福州网站建设熊掌号,wordpress superchanger本文主要介绍国外google上线的app 短信自动填充方案。 本方案主要是使用google提出的#xff0c;防止开发者使用SMS相关权限造成的用户信息泄露 目录 注意点#xff1a; 1、本方式不适合华为手机#xff0c;华为有自己的获取方式 2、本方式不需要添加任何短信权限 3、…本文主要介绍国外google上线的app 短信自动填充方案。 本方案主要是使用google提出的防止开发者使用SMS相关权限造成的用户信息泄露 目录 注意点 1、本方式不适合华为手机华为有自己的获取方式 2、本方式不需要添加任何短信权限 3、项目版本 开发成本 Android代码 1、导库 1在项目根目录的build.gradle中添加下面代码 2项目级build.gradle引用库 2、注册广播 1静态注册 2动态注册 3、启动监听 4、广播代码 其他开发成本 短信模板 短信后i按加上11位哈市值 1命令mac 命令 2代码放入项目中运行打包、启动app注意debug签名与正是签名包的不同正式的hashcode  需要正式打包然后打印出来 注意点 1、本方式不适合华为手机华为有自己的获取方式 2、本方式不需要添加任何短信权限 3、项目版本 compileSdkVersion34 minSdkVersion19 开发成本 app需要集成两个google库后端只需要改短信模板在短信后面添加11位hash值hash值生成方式在下面链接可以看到 google开发地址国内需要翻墙 Android代码 1、导库 1在项目根目录的build.gradle中添加下面代码 buildscript {repositories {...google()mavenCentral()} }allprojects {repositories { google()mavenCentral()} } 2项目级build.gradle引用库 dependencies {implementation com.google.android.gms:play-services-auth:21.2.0implementation com.google.android.gms:play-services-auth-api-phone:18.1.0 } 2、注册广播 1静态注册 receiverandroid:name路径.MySMSBroadcastReceiverandroid:exportedtrueandroid:permissioncom.google.android.gms.auth.api.phone.permission.SENDintent-filteraction android:namecom.google.android.gms.auth.api.phone.SMS_RETRIEVED //intent-filter/receiver 2动态注册 if(smsBrodnull){smsBrod MySMSBroadcastReceiver(this,null)}val intentFilter IntentFilter();intentFilter.addAction(SmsRetriever.SMS_RETRIEVED_ACTION);if (Build.VERSION.SDK_INT Build.VERSION_CODES.O) {thisTestAlendActivity.registerReceiver(smsBrod,intentFilter,SmsRetriever.SEND_PERMISSION,null, Context.RECEIVER_EXPORTED)} 3、启动监听 fun googleMSM() {val client SmsRetriever.getClient(this)val task: TaskVoid client.startSmsRetriever()task.addOnSuccessListener(OnSuccessListenerVoid? {Log.i(SMS_CON, googleMSM addOnSuccessListener)if(smsBrodnull){smsBrod MySMSBroadcastReceiver(this,null)}val intentFilter IntentFilter();intentFilter.addAction(SmsRetriever.SMS_RETRIEVED_ACTION);if (Build.VERSION.SDK_INT Build.VERSION_CODES.O) {thisTestAlendActivity.registerReceiver(smsBrod,intentFilter,SmsRetriever.SEND_PERMISSION,null, Context.RECEIVER_EXPORTED)}})task.addOnFailureListener(OnFailureListener {Log.i(SMS_CON, googleMSM addOnFailureListener)})} 4、广播代码 import android.app.Activity; import android.content.BroadcastReceiver; import android.content.Context; import android.content.Intent; import android.os.Bundle; import android.util.Log; import android.widget.Toast;import com.google.android.gms.auth.api.phone.SmsRetriever; import com.google.android.gms.common.api.CommonStatusCodes; import com.google.android.gms.common.api.Status;import org.json.JSONException; import org.json.JSONObject;import java.lang.ref.SoftReference; import java.util.regex.Matcher; import java.util.regex.Pattern;/*** BroadcastReceiver to wait for SMS messages. This can be registered either* in the AndroidManifest or at runtime. Should filter Intents on* SmsRetriever.SMS_RETRIEVED_ACTION.*/ public class MySMSBroadcastReceiver extends BroadcastReceiver {public MySMSBroadcastReceiver() {}Overridepublic void onReceive(Context context, Intent intent) {Log.i(SMS_CON, googleMSM MySMSBroadcastReceiver action intent.getAction());if (SmsRetriever.SMS_RETRIEVED_ACTION.equals(intent.getAction())) {Bundle extras intent.getExtras();Status status (Status) extras.get(SmsRetriever.EXTRA_STATUS);Log.i(SMS_CON, status status);if(status!null){switch (status.getStatusCode()) {case CommonStatusCodes.SUCCESS:// (Optional) Get SMS Sender address - only available in// GMS version 24.20 onwards, else it will return null // String senderAddress extras.getString(SmsRetriever.EXTRA_SMS_ORIGINATING_ADDRESS);// Get SMS message contentsString message extras.getString(SmsRetriever.EXTRA_SMS_MESSAGE);// Extract one-time code from the message and complete verification// by sending the code back to your server.Log.i(SMS_CON, message message);if (message ! null) {Pattern code Pattern.compile((\\d{6}));Matcher matcher code.matcher(message);String otp ;if (matcher.find()) {otp matcher.group(0);} else {otp message;}Log.i(SMS_CON, otp otp);Toast.makeText(context,otp\notp,Toast.LENGTH_LONG).show();}break;case CommonStatusCodes.TIMEOUT:// Waiting for SMS timed out (5 minutes)// Handle the error ...Log.i(SMS_CON, TIMEOUT );break;}}}} } 其他开发成本 短信模板 短信后i按加上11位哈市值 Hash值生成方式 1命令mac 命令 keytool -exportcert -keystore keystory名称.jks -storepass 你的密码 -alias 别名 | xxd -p  | tr -d [:space:] | echo -n 你的包名 cat | shasum -a 256 | tr -d [:space:]- | xxd -r -p | base64 | cut -c1-11 2代码放入项目中运行打包、启动app注意debug签名与正是签名包的不同正式的hashcode  需要正式打包然后打印出来 aab文件也可以通过命令安装到手机网上搜一下 bundletool.jar 这个工具 import android.annotation.TargetApi; import android.content.Context; import android.content.ContextWrapper; import android.content.pm.PackageManager; import android.content.pm.Signature; import android.util.Base64; import android.util.Log;import java.nio.charset.StandardCharsets; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.ArrayList; import java.util.Arrays;public class AppSignatureHashHelper extends ContextWrapper {public static final String TAG AppSignatureHashHelper.class.getSimpleName();private static final String HASH_TYPE SHA-256;public static final int NUM_HASHED_BYTES 9;public static final int NUM_BASE64_CHAR 11;public AppSignatureHashHelper(Context context) {super(context);}public ArrayListString getAppSignatures() {ArrayListString appSignaturesHashs new ArrayList();try {String packageName getPackageName();PackageManager packageManager getPackageManager();Signature[] signatures packageManager.getPackageInfo(packageName,PackageManager.GET_SIGNATURES).signatures;for (Signature signature : signatures) {String hash hash(packageName, signature.toCharsString());if (hash ! null) {appSignaturesHashs.add(String.format(%s, hash));}}} catch (Exception e) {Log.e(TAG, Package not found, e);}return appSignaturesHashs;}TargetApi(19)private static String hash(String packageName, String signature) {String appInfo packageName signature;try {MessageDigest messageDigest MessageDigest.getInstance(HASH_TYPE);messageDigest.update(appInfo.getBytes(StandardCharsets.UTF_8));byte[] hashSignature messageDigest.digest();hashSignature Arrays.copyOfRange(hashSignature, 0, NUM_HASHED_BYTES);String base64Hash Base64.encodeToString(hashSignature, Base64.NO_PADDING | Base64.NO_WRAP);base64Hash base64Hash.substring(0, NUM_BASE64_CHAR);return base64Hash;} catch (NoSuchAlgorithmException e) {Log.e(TAG, No Such Algorithm Exception, e);}return null;} } 调用方式 String hashcodeStr AppSignatureHashHelper(this).getAppSignatures() 上面会生成11位hash值放在短信后面就行了 ***以上是获取短信短信自动填充代码就不写了拿到字符串 设置到输入框就行推荐按使用动态注册可以给广播传入回调接口处理返回的验证码otp 到这里就完成了上面获取命令的方式是通过自己签名的方式如果是让google生成签名则需要去看链接里的步骤比较详细 测试的话 可以让别人发短信给你 在app里会受到广播
http://www.hkea.cn/news/14396463/

相关文章:

  • 微信怎么建小网站网站域名可以更改吗
  • 怎样制作微信网站链接饲料网站源码
  • 制作免费网站的平台做电影方面的网站怎么做
  • php完整网站开发源码大连市住建局官方网
  • 零基础建网站嘉兴公司注册
  • 个人网站空间收费wordpress setup-config.php空白
  • 流行网站类型800元建网站
  • 个人网站备案经验企业网站建设开发成本利润多少
  • 做外贸网站需要请外贸文员吗网上做图赚钱的网站
  • 公司网站需要修改网页制作模板源码
  • 怎样做网站的关键词h5商城和小程序商城的区别
  • 网站建设资源分享wordpress点击创建配置文件没反应
  • 流量购买网站window2008r2网站建设
  • 长春网站优化公司百度网盟网站有哪些
  • 万户网站协作管理系统网站备案年审
  • 网站建设维护是啥意思东莞如何搭建网站建设
  • wordpress网站跳转nginxphp网站识别手机
  • 搜索网站怎么做学院校园网网站建设情况
  • 河南网站建设app开发丽水专业做网站
  • 广西新站seo上海浦东哪里有做网站的公司
  • 天津网站建设诺亚音乐如何到wordpress
  • 网站如何做301跳转网站如何做百度搜索优化
  • 怎么做福彩网站查域名的网址
  • 个体工商户网站备案流程平面设计怎么接单
  • wdcp新建网站第一次和两个老头做网站
  • 濂溪区建设局网站怎么做百度自己的网站空间
  • 做网站公众号要多少钱广州建设公司
  • 网站优化排名工具东莞微网站
  • 供求信息网站开发背景北碚区建设银行网站
  • 西安好玩的地方排行榜宁波网络seo推广