我正在创建一个这样的digitsauthconfig:
private DigitsAuthConfig createDigitsAuthConfig() {
return new DigitsAuthConfig.Builder()
.withAuthCallBack(createAuthCallback())
.withPhoneNumber("+91")
.withThemeResId(R.style.CustomDigitsTheme)
.build();
}
返回authcallback的地方是:
private AuthCallback createAuthCallback() {
return new AuthCallback() {
@Override
public void success(DigitsSession session, String phoneNumber) {
doIfSuccessfulOtpVerification();
}
@Override
public void failure(DigitsException exception) {
doIfNotSuccessfulOtpVerification();
}
};
}
我使用带有事件监听器的按钮启动该过程:
digitsButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Digits.authenticate(createDigitsAuthConfig());
}
});
问题是,一旦我的电话号码被验证,它就会返回到显示按钮的活动,什么都不做。从技术上讲,authcallback永远不会被调用,不管成功与否。但是如果我再次单击该按钮,则会调用authcallback而不重复验证步骤。所以现在我需要点击两次按钮。 它的方法是什么?
答案 0 :(得分:4)
最后我得到了这个问题的解决方案,也许它也会帮助你。
您需要在调用setCallback(authCallback)
之前删除ActiveSession,如下所述。它将从数字中删除现有会话(如果您已输入电话号码并获得OTP)。此会话将不允许您进行另一个会话以生成OTP。所以,我们必须删除它。如果之前没有任何会话,它将会有效。
DigitsAuthButton digitsButton = (DigitsAuthButton) findViewById(R.id.auth_button);
Digits.getSessionManager().clearActiveSession();
digitsButton.setCallback(((WyzConnectApp) getApplication()).getAuthCallback());
答案 1 :(得分:0)
Digits改变了引用Digits#authenticate调用中传递的AuthCallback的方式
现在Digits保持一个弱引用(以避免内存泄漏),除非你持有强引用,AuthCallback将被垃圾收集并且流的结果将永远不会传播。
您需要在Application上下文中定义AuthCallback,然后在您的活动中使用此回调,它应该可以工作
请查看documentation如何执行此操作
答案 2 :(得分:0)
我知道它很晚但可能对初学者有帮助。要验证会话是否已激活,请将此代码放入您初始化Digits电话号码验证按钮的onCreate
活动中:
TwitterAuthConfig authConfig = new TwitterAuthConfig(TWITTER_KEY, TWITTER_SECRET);
Fabric.with(this, new TwitterCore(authConfig), new Digits.Builder().build());
if (Digits.getActiveSession() != null) {
Intent ss = new Intent(CurrentActivity.this, SecondActivity.class);
startActivity(ss);
finish();
}