- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在装有 Android 9 的 Motorola One 手机中使用 Android 自动短信验证方法 ( https://developers.google.com/identity/sms-retriever/request ),当提示选择电话号码时,它只显示一个,而不是两个。我尝试在 Google 上查找此内容,但没有发现任何类似内容。
我的代码测试是:
HintRequest hintRequest = new HintRequest.Builder()
.setPhoneNumberIdentifierSupported(true)
.build();
GoogleApiClient mGoogleApiClient = new GoogleApiClient.Builder(this)
.addApi(Auth.CREDENTIALS_API)
.addConnectionCallbacks(new GoogleApiClient.ConnectionCallbacks() {
@Override
public void onConnected(@Nullable Bundle bundle) {
Log.i(TAG_LOG, "google api connected");
}
@Override
public void onConnectionSuspended(int i) {
Log.i(TAG_LOG, "google api suspended: " + i);
}
})
.enableAutoManage(this, new GoogleApiClient.OnConnectionFailedListener() {
@Override
public void onConnectionFailed(@NonNull ConnectionResult connectionResult) {
Log.i(TAG_LOG, "google api connect failed: " );
}
})
.build();
PendingIntent intent = Auth.CredentialsApi.getHintPickerIntent(
mGoogleApiClient, hintRequest);
try {
startIntentSenderForResult(intent.getIntentSender(),
RESOLVE_HINT, null, 0, 0, 0);
} catch (IntentSender.SendIntentException e) {
e.printStackTrace();
}
有什么想法吗?
最佳答案
公共(public)类 MobileNumberActivity 扩展 AppCompatActivity 实现 View.OnClickListener、GoogleApiClient.ConnectionCallbacks、GoogleApiClient.OnConnectionFailedListener {
private String mob;
EditText etMobileNumber;
TypedInput input;
ViewDialog viewDialog;
String TOKEN = "token";
GoogleApiClient apiClient;
int RC_HINT = 1008;
SharedPreferences sharedpreferences;
Intent i;
String intenString;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_mobile_number);
i = getIntent();
intenString = i.getStringExtra("google_login");
sharedpreferences = getSharedPreferences(TOKEN, Context.MODE_PRIVATE);
etMobileNumber = findViewById(R.id.etPhoneNumber);
mob = etMobileNumber.getText().toString();
Button send_otp = findViewById(R.id.continue_button);
send_otp.setOnClickListener(this);
viewDialog = new ViewDialog(MobileNumberActivity.this);
getCreadenticalApiClient();
showHint();
}
@Override
public void onClick(View v) {
if (v.getId() == R.id.continue_button) {
if (etMobileNumber.getText().toString().trim().length() == 0) {
Toasty.error(MobileNumberActivity.this, "Please Enter Mobile Number", Toast.LENGTH_SHORT, true).show();
} else if (etMobileNumber.getText().toString().trim().length() < 10) {
Toasty.error(MobileNumberActivity.this, "Please Enter Valid Mobile Number", Toast.LENGTH_SHORT, true).show();
} else {
if (getIntent().getExtras()!=null) {
try {
JSONObject object = new JSONObject();
object.put("mb", etMobileNumber.getText().toString());
object.put("token", Constant.token);
input = new TypedByteArray("application/json", object.toString().getBytes());
Log.d("tmz", object.toString());
if (Network.isConnectedToNetwork(MobileNumberActivity.this)) {
phoneLoginApi();
} else {
Toasty.error(MobileNumberActivity.this, "Please Connect To Internet!", Toast.LENGTH_SHORT, true).show();
overridePendingTransition(R.anim.fade_in, R.anim.fade_out);
finish();
}
} catch (Exception e) {
e.printStackTrace();
}
}else{
try {
JSONObject object = new JSONObject();
object.put("mb", etMobileNumber.getText().toString());
input = new TypedByteArray("application/json", object.toString().getBytes());
Log.d("tmz", object.toString());
if (Network.isConnectedToNetwork(MobileNumberActivity.this)) {
phoneLoginApi();
} else {
Toasty.error(MobileNumberActivity.this, "Please Connect To Internet!", Toast.LENGTH_SHORT, true).show();
overridePendingTransition(R.anim.fade_in, R.anim.fade_out);
finish();
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
}
private void phoneLoginApi() {
viewDialog.showDialog();
RequestInterceptor requestInterceptor = new RequestInterceptor() {
@Override
public void intercept(RequestFacade request) {
request.addHeader("Content-Type", "application/json");
request.addHeader("Connection", "close");
}
};
RestAdapter restAdapter = new RestAdapter.Builder()
.setLogLevel(RestAdapter.LogLevel.FULL)
.setRequestInterceptor(requestInterceptor)
.setEndpoint(Constant.Server_Url)
.build();
PostInterfaces api = restAdapter.create(PostInterfaces.class);
api.signinwithMobile(input, new Callback<Response>() {
@Override
public void success(Response result, Response response) {
BufferedReader reader;
String output;
try {
reader = new BufferedReader(new InputStreamReader(result.getBody().in()));
output = reader.readLine();
JSONObject object = new JSONObject(output);
String response_string = object.getString("status");
Constant.token = object.getString("token");
Constant.message = object.getString("message");
if (response_string.equals("0")) {
viewDialog.hideDialog();
startActivity(new Intent(MobileNumberActivity.this, OtpActivity.class));
overridePendingTransition(R.anim.push_in_to_left, R.anim.push_in_to_right);
finish();
}
// Test Pending //
else if (response_string.equals("1")) {
viewDialog.hideDialog();
startActivity(new Intent(MobileNumberActivity.this, OtpActivity.class));
overridePendingTransition(R.anim.push_in_to_left, R.anim.push_in_to_right);
finish();
}
} catch (Exception e) {
Toast.makeText(MobileNumberActivity.this, "Error: " + e.toString(), Toast.LENGTH_SHORT).show();
}
}
@Override
public void failure(RetrofitError error) {
Toast.makeText(MobileNumberActivity.this, error.toString(), Toast.LENGTH_SHORT).show();
}
});
}
**private void showHint() {
HintRequest hintRequest = new HintRequest.Builder()
.setHintPickerConfig(new CredentialPickerConfig.Builder()
.setShowCancelButton(true)
.build())
.setPhoneNumberIdentifierSupported(true)
.build();
PendingIntent intent =
Auth.CredentialsApi.getHintPickerIntent(apiClient, hintRequest);
try {
startIntentSenderForResult(intent.getIntentSender(), RC_HINT, null, 0, 0, 0, new Bundle());
} catch (IntentSender.SendIntentException e) {
Log.e("Login", "Could not start hint picker Intent", e);
}
}
private void getCreadenticalApiClient() {
apiClient = new GoogleApiClient.Builder(getBaseContext())
.addConnectionCallbacks(this)
.enableAutoManage(MobileNumberActivity.this, this)
.addApi(Auth.CREDENTIALS_API)
.build();
}**
@Override
public void onConnected(@Nullable Bundle bundle) {
}
@Override
public void onConnectionSuspended(int i) {
}
@Override
public void onConnectionFailed(@NonNull ConnectionResult connectionResult) {
}
**@Override
protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == RC_HINT) {
if (resultCode == RESULT_OK) {
assert data != null;
Credential cred = data.getParcelableExtra(Credential.EXTRA_KEY);
etMobileNumber.setText(cred.getId().substring(3));
}
}
}**
@Override
public void onBackPressed() {
super.onBackPressed();
SharedPreferences.Editor editor = sharedpreferences.edit();
editor.clear();
editor.apply();
}
}
关于java - Android - 手机选择器 (HintRequest) 在双 SIM 卡手机上不显示两个号码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58833146/
在 Android 的 API > 19 中是否有任何方法可以获取可移动 SD 卡的路径? 与外部 SD 卡一样,我们有 Environment.getExternalStorageDirectory
一些 Android 设备有 microSD(或其他存储卡)插槽,通常安装为 /storage/sdcard1 据我所知,自 Android 4.4 起 Google 限制了对此内存的访问,并在 An
我使用 Java Card 2.1.2 SDK 和 GPShell 作为与设备通信的方式在 Java Card 上构建一个项目。我从 GpShell 测试了 helloworld 示例,并成功发送了
我开发了一个应用程序,它有一个来电接收器,它适用于所有手机。一位用户有一部双 SIM 卡安卓手机。该应用程序适用于第一张 SIM 卡。但是当有人调用他的第二张 SIM 卡时,我们的应用程序不会被调用。
我有一个带预览的文件输入。 这是笔 Codepen 我想强制高度,我无法理解我该怎么做。我想将此组件的高度固定为 300px(示例),我还需要保持加载图像的正确纵横比,用灰色背景填充空白。现在我保持宽
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 6年前关闭。 Improve this qu
我正在使用此代码访问 SD card : import os from os.path import join from jnius import autoclass #from android.pe
我正在为数据记录设备编写固件。它以 20 Hz 的频率从传感器读取数据并将数据写入 SD 卡。但是,向SD卡写入数据的时间并不一致(大约200-300 ms)。因此,一种解决方案是以一致的速率将数据写
我正在使用以下代码将视频放到网站上,但是在垂直方向上,手机屏幕上只能看到视频的左半部分 我不是网络开发人员。有人可以告诉我确切的内容吗,如何使其正确放置在手机屏幕上? 是在youtube iframe
我正在使用 Vuetify 1.5 和 Vuetify 网格系统来设置我的布局。现在我有一个组件 HelloWorld我将其导入到我的 Parent 中成分。我已经在我的 HelloWorld 中设置
我使用 python 制作了一个简单的二十一点游戏。我制作了游戏的其余部分,但我正在努力放入 ASCII 卡,所以这只是代码的一小部分。我尝试将 * len(phand) 放在附加行的末尾。虽然这确实
我正在使用玩家卡设置 Twitter 卡。它可以在预览工具中运行,但文档说它需要在“twitter.com 现代桌面浏览器? native iOs 和 Android Twitter 应用程序?mob
任何旧的 GSM 兼容 SIM 卡(3G USIM 的奖励)。 我想我需要一些硬件?谁能为业余爱好者推荐一些便宜的东西,以及一些更专业的东西? 我认为会有一个带有硬件的 API 的完整文档,所以也许这
我使用 python 制作了一个简单的二十一点游戏。我制作了游戏的其余部分,但我正在努力放入 ASCII 卡,所以这只是代码的一小部分。我尝试将 * len(phand) 放在附加行的末尾。虽然这确实
我记得前一段时间读到有 cpu 卡供系统添加额外的处理能力来进行大规模并行化。任何人都有这方面的经验和任何资源来研究项目的硬件和软件方面吗?这项技术是否不如传统集群?它更注重功率吗? 最佳答案 有两个
我检查外部存储是否已安装并且可用于读/写,然后从中读取。我使用的是确切的官方 Android 示例代码 ( from here )。 它说外部存储未安装。 getExternalFilesDir(nu
在 Android 2.1 及更低版本中,Android 应用程序可以请求下载到 SD 卡上吗?另外我想知道应用程序是否可以请求一些包含视频的文件夹下载到 SD 卡上?以及如何做到这一点? 提前致谢。
我们编写了一个 Windows 设备驱动程序来访问我们的自定义 PCI 卡。驱动程序使用 CreateFile 获取卡的句柄。 我们最近在一次安装中遇到了问题,卡似乎停止工作了。我们尝试更换卡(更换似
有些新设备(例如 Samsung Galaxy)带有两个 SD 卡。我想知道是否有任何方法可以确定设备是否有两张 SD 卡或一张 SD 卡。谢谢 最佳答案 我认为唯一的方法是使用 检查可用根的列表 F
我正在尝试将文件读/写到 SD 卡。我已经尝试在我的真实手机和 Eclipse 中的模拟器上执行此操作。在这两种设备上,对/mnt/sdcard/或/sdcard 的权限仅为“d--------”,我
我是一名优秀的程序员,十分优秀!