- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的 Google 登录功能/w Firebase 工作正常好几天,直到我退出后突然无法再次登录。它抛出这个异常:
04-28 23:28:17.639 1991-2393/com.google.android.gms.persistent W/GLSUser: [AppCertManager] IOException while requesting key:
java.io.IOException: Invalid device key response.
at evk.a(:com.google.android.gms:274)
at evk.a(:com.google.android.gms:4238)
at evk.a(:com.google.android.gms:170)
at evj.a(:com.google.android.gms:63)
at evh.onTransact(:com.google.android.gms:58)
at android.os.Binder.transact(Binder.java:499)
at bxp.onTransact(:com.google.android.gms:35)
at android.os.Binder.execTransact(Binder.java:565)
04-28 23:28:17.640 1991-2393/com.google.android.gms.persistent W/GLSUser: [DeviceKeyStore] Cannot load key: Device key file not found.
04-28 23:28:17.890 2371-4189/com.google.android.gms E/Volley: [327] BasicNetwork.performRequest: Unexpected response code 400 for https://www.googleapis.com/identitytoolkit/v3/relyingparty/verifyAssertion?key=AIzaSyAdxh0yBc4QUZ4-CjcOn472ieduZiShkwY
04-28 23:28:17.894 2371-22212/com.google.android.gms I/AuthChimeraService: Error description received from server: {
"error": {
"errors": [
{
"domain": "global",
"reason": "invalid",
"message": "Invalid id_token in IdP response: eyJhbGciOiJSUzI1NiIsImtpZCI6ImNmYWVjZjI5MWFhM2M4YWZiMDg2ZGUxYmU3ZGJlNmM3NjMyODI3NDYifQ.eyJhenAiOiIyMzA4MzIzMTgwMjQtdmM5am1udmRydTVzMGYyaXNldnM2cm8zdTA3Nm1vYmouYXBwcy5nb29nbGV1c2VyY29udGVudC5jb20iLCJhdWQiOiIyMzA4MzIzMTgwMjQtbTZuMDFpampnYWI5cjdpYmdlNmE3ODQ0M2xvYzRlNW8uYXBwcy5nb29nbGV1c2VyY29udGVudC5jb20iLCJzdWIiOiIxMTI5MTM1Mzg1MDg1MjY2MDU0MzciLCJlbWFpbCI6ImF2aWFtaXJzd2VAZ21haWwuY29tIiwiZW1haWxfdmVyaWZpZWQiOnRydWUsImlzcyI6Imh0dHBzOi8vYWNjb3VudHMuZ29vZ2xlLmNvbSIsImlhdCI6MTQ5MzQ2OTg0MSwiZXhwIjoxNDkzNDczNDQxLCJuYW1lIjoiQWxpIEFtaWQiLCJwaWN0dXJlIjoiaHR0cHM6Ly9saDQuZ29vZ2xldXNlcmNvbnRlbnQuY29tLy1aZXVWdDZ6d1o4WS9BQUFBQUFBQUFBSS9BQUFBQUFBQUFBQS9BSGFsR2hxN2w5cW0xNlY4bDduZVNYdFdPMjlFSDVkLTVRL3M5Ni1jL3Bob3RvLmpwZyIsImdpdmVuX25hbWUiOiJBbGkiLCJmYW1pbHlfbmFtZSI6IkFtaWQiLCJsb2NhbGUiOiJlbiJ9.EyuUL2ONyko0VuwoRRxFcxCL1R6K3pYpDGx-poPa9jfj20jwALhg8aGArA_NZpg1qttTMagHrkfaaaNA2yvWZmy4nmvxoXKBHYRfjpatUstKd7GKcA28cJrONlM8ixEaI7Sie344jv53lLwbhpIb_OFjJWMVsQ3DoG9A-63nSliQC2LfAje2EcOaoDD7y3rDRKluRM18fmAijH6yKfR9PXNDKFOWDfWOC4XlXxuLvl18xUv8ExA-oZeHM8D_mF9p02ipEq_EyzQUwUzcVDjoJPeb_qDFjaHXZJ4KKD3pv30m8YP8LLQ6t_GXJwphwpqYVydGuIPHLsHz4Pmo-pP17w, error: Id_token failed validation."
}
],
"code": 400,
"message": "Invalid id_token in IdP response: eyJhbGciOiJSUzI1NiIsImtpZCI6ImNmYWVjZjI5MWFhM2M4YWZiMDg2ZGUxYmU3ZGJlNmM3NjMyODI3NDYifQ.eyJhenAiOiIyMzA4MzIzMTgwMjQtdmM5am1udmRydTVzMGYyaXNldnM2cm8zdTA3Nm1vYmouYXBwcy5nb29nbGV1c2VyY29udGVudC5jb20iLCJhdWQiOiIyMzA4MzIzMTgwMjQtbTZuMDFpampnYWI5cjdpYmdlNmE3ODQ0M2xvYzRlNW8uYXBwcy5nb29nbGV1c2VyY29udGVudC5jb20iLCJzdWIiOiIxMTI5MTM1Mzg1MDg1MjY2MDU0MzciLCJlbWFpbCI6ImF2aWFtaXJzd2VAZ21haWwuY29tIiwiZW1haWxfdmVyaWZpZWQiOnRydWUsImlzcyI6Imh0dHBzOi8vYWNjb3VudHMuZ29vZ2xlLmNvbSIsImlhdCI6MTQ5MzQ2OTg0MSwiZXhwIjoxNDkzNDczNDQxLCJuYW1lIjoiQWxpIEFtaWQiLCJwaWN0dXJlIjoiaHR0cHM6Ly9saDQuZ29vZ2xldXNlcmNvbnRlbnQuY29tLy1aZXVWdDZ6d1o4WS9BQUFBQUFBQUFBSS9BQUFBQUFBQUFBQS9BSGFsR2hxN2w5cW0xNlY4bDduZVNYdFdPMjlFSDVkLTVRL3M5Ni1jL3Bob3RvLmpwZyIsImdpdmVuX25hbWUiOiJBbGkiLCJmYW1pbHlfbmFtZSI6IkFtaWQiLCJsb2NhbGUiOiJlbiJ9.EyuUL2ONyko0VuwoRRxFcxCL1R6K3pYpDGx-poPa9jfj20jwALhg8aGArA_NZpg1qttTMagHrkfaaaNA2yvWZmy4nmvxoXKBHYRfjpatUstKd7GKcA28cJrONlM8ixEaI7Sie344jv53lLwbhpIb_OFjJWMVsQ3DoG9A-63nSliQC2LfAje2EcOaoDD7y3rDRKluRM18fmAijH6yKfR9PXNDKFOWDfWOC4XlXxuLvl18xUv8ExA-oZeHM8D_mF9p02ipEq_EyzQUwUzcVDjoJPeb_qDFjaHXZJ4KKD3pv30m8YP8LLQ6t_GXJwphwpqYVydGuIPHLsHz4Pmo-pP17w, error: Id_token failed validation."
}
}
04-28 23:28:17.897 22376-22376/com.appD/com.app.activity.SignInActivity: signInWithCredential:onComplete:false
04-28 23:28:17.897 22376-22376/com.appW/com.app.activity.SignInActivity: signInWithCredential
com.google.firebase.FirebaseException: An internal error has occurred. [ Invalid id_token in IdP response ]
at com.google.android.gms.internal.zzblv.zzce(Unknown Source)
at com.google.android.gms.internal.zzbls$zzj.zza(Unknown Source)
at com.google.android.gms.internal.zzbmd.zzcf(Unknown Source)
at com.google.android.gms.internal.zzbmd$zza.onFailure(Unknown Source)
at com.google.android.gms.internal.zzbly$zza.onTransact(Unknown Source)
at android.os.Binder.execTransact(Binder.java:565)
我注销的代码:
//init google options
if(gso != null){
gso = new GoogleSignInOptions.Builder(GoogleSignInOptions.DEFAULT_SIGN_IN)
.requestIdToken(getString(R.string.default_web_client_id))
.requestEmail()
.build();
}
if(mGoogleApiClient != null){
mGoogleApiClient = new GoogleApiClient.Builder(getActivity())
.enableAutoManage(getActivity(), this)
.addApi(Auth.GOOGLE_SIGN_IN_API, gso)
.build();
}
//init sign out button and add an onclicklistener
signOut = (Button) rootView.findViewById(R.id.sign_out_button);
signOut.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
//Log out user from both FirebaseAuth and Google
mFirebaseAuth.signOut();
Auth.GoogleSignInApi.signOut(mGoogleApiClient);
startActivity(new Intent(getContext(), SignInActivity.class));
}
});
我登录的代码:
public class SignInActivity extends AppCompatActivity implements
GoogleApiClient.OnConnectionFailedListener, View.OnClickListener {
private static final String TAG = SignInActivity.class.getName();
private static final int RC_SIGN_IN = 9001;
private SignInButton mSignInButton;
private GoogleApiClient mGoogleApiClient;
// Firebase instance variables
private FirebaseAuth mFirebaseAuth;
private FirebaseUser mFirebaseUser;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_sign_in);
// Assign fields
mSignInButton = (SignInButton) findViewById(R.id.sign_in_button);
// Set click listeners
mSignInButton.setOnClickListener(this);
// Configure Google Sign In
GoogleSignInOptions gso = new GoogleSignInOptions.Builder(GoogleSignInOptions.DEFAULT_SIGN_IN)
.requestIdToken(getString(R.string.default_web_client_id))
.requestEmail()
.build();
mGoogleApiClient = new GoogleApiClient.Builder(this)
.enableAutoManage(this, this)
.addApi(Auth.GOOGLE_SIGN_IN_API, gso)
.build();
// Initialize FirebaseAuth
mFirebaseAuth = FirebaseAuth.getInstance();
mFirebaseUser = mFirebaseAuth.getCurrentUser();
}
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.sign_in_button:
signIn();
break;
}
}
@Override
public void onConnectionFailed(@NonNull ConnectionResult connectionResult) {
// An unresolvable error has occurred and Google APIs (including Sign-In) will not
// be available.
Log.d(TAG, "onConnectionFailed:" + connectionResult);
Toast.makeText(this, "Google Play Services error.", Toast.LENGTH_SHORT).show();
}
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
// Result returned from launching the Intent from GoogleSignInApi.getSignInIntent(...);
if (requestCode == RC_SIGN_IN) {
GoogleSignInResult result = Auth.GoogleSignInApi.getSignInResultFromIntent(data);
if (result.isSuccess()) {
// Google Sign-In was successful, authenticate with Firebase
GoogleSignInAccount account = result.getSignInAccount();
firebaseAuthWithGoogle(account);
} else {
// Google Sign-In failed
Log.e(TAG, "Google Sign-In failed.");
}
}
}
private void signIn() {
Intent signInIntent = Auth.GoogleSignInApi.getSignInIntent(mGoogleApiClient);
startActivityForResult(signInIntent, RC_SIGN_IN);
}
private void firebaseAuthWithGoogle(GoogleSignInAccount acct) {
Log.d(TAG, "firebaseAuthWithGooogle:" + acct.getId());
AuthCredential credential = GoogleAuthProvider.getCredential(acct.getIdToken(), null);
mFirebaseAuth.signInWithCredential(credential)
.addOnCompleteListener(this, new OnCompleteListener<AuthResult>() {
@Override
public void onComplete(@NonNull Task<AuthResult> task) {
Log.d(TAG, "signInWithCredential:onComplete:" + task.isSuccessful());
// If sign in fails, display a message to the user. If sign in succeeds
// the auth state listener will be notified and logic to handle the
// signed in user can be handled in the listener.
if (!task.isSuccessful()) {
Log.w(TAG, "signInWithCredential", task.getException());
Toast.makeText(SignInActivity.this, "Authentication failed.",
Toast.LENGTH_SHORT).show();
} else {
startActivity(new Intent(SignInActivity.this, MainActivity.class));
finish();
}
}
});
}
@Override
public void onDestroy() {
super.onDestroy();
mGoogleApiClient.stopAutoManage(this);
mGoogleApiClient.disconnect();
}
}
登录来自一个 Activity ,注销来自附加到另一 Activity 的 fragment (如果此信息在某种程度上相关)。
在方法 firebaseAuthWithGoogle(GoogleSignInAccount acct)
(在 SignInActivity.java 中)中,身份验证失败。具体来说,mFirebaseAuth.signInWithCredential(credential)
失败。
我不知道为什么会发生这个错误,有人知道为什么吗?
最佳答案
Firebase 库已于昨天更新至 10.2.4: https://firebase.google.com/support/releases
我更新了 build.gradle 文件以使 Firebase 库版本与 Google Play 服务版本同步:
compile 'com.google.firebase:firebase-database:10.2.4'
compile 'com.google.firebase:firebase-core:10.2.4'
compile 'com.google.firebase:firebase-auth:10.2.4'
compile 'com.google.firebase:firebase-messaging:10.2.4'
compile 'com.google.android.gms:play-services-wearable:10.2.4'
compile 'com.google.android.gms:play-services-auth:10.2.4'
我不确定是否有必要,但我从模拟器中卸载了我的应用程序并重新部署了它。
我确实在日志记录中看到了“无效的设备 key 响应”错误,但在进行 build.gradle 更新之前看到的“IdP 响应中的无效 id_token”错误现已消失。我的用户已成功登录。
关于android - Google 登录(使用 Firebase)突然停止工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43696837/
我正在使用 Tkinter 在 python 上写一个小游戏(顺便说一下,我不允许使用任何其他非内置模块)并且我想在主窗口上播放背景歌曲,这是那个包含标题,以及转到其他窗口和内容的按钮... 所以问题
我有一个 Azure WebJob,它在一个非常简单的应用服务标准:1 Small(计划)上运行。 现在,我的 WebJob(有 5 个函数正在运行)出现问题 - 我想停止 5 个正在运行的函数中的
我在 MacOS Lion 上使用 XCode 4.2。在模拟器中调试 iPhone/iPad 应用程序时,我使用 XCode 工具栏上的“停止”按钮(产品 | 停止)退出应用程序。在此之后,XCod
我刚刚下载了android开放源代码项目,并尝试使用make来构建它,我收到了以下消息: build/core/prebuilt.mk:91: *** recipe commences before
我以前从未制作过 makefile,但我们已经收到了这个,但是,如果我尝试运行它,它只会说, missing separator. stop. 我不知道可能出了什么问题 - 我已经确保空格只按制表符。
好吧,这段代码非常基本。用户将答案输入文本框,如果等于“第一+第二”,他们就得到一分。然后,他们有 5 秒钟的时间回答下一个数学问题。如果他们这样做了,函数“doCalculation”将再次运行,他
我在 viewController 中有一个循环动画 - (void)moveAnimating { [UIView animateWithDuration:2.0f animations:^
当我有一个待处理的 ASIFormDataRequest(作为异步任务启动)仍在执行并且用户按下后退按钮(为了弹出 View )时,我的 viewController 出现问题。 有什么方法可以停止该
我们正在使用 flashdevelop 和 flash CS 3 开发基于 flash 的游戏。我们正在使用 flash CS3 发布 swc,swc 将作为库在 flashdevlop 中使用。 一
我在线程中有一个连接,因此我将其添加到运行循环中以获取所有数据: [[NSRunLoop currentRunLoop] run]; [connection scheduleInRunLoop
你好,我做了一个 php 套接字服务器来从 plc 获取数据,plc 被配置为 tcp 套接字客户端。 我有一个严重的问题,如果本地网络出现故障,似乎功能 socket_accept 停止,plc 无
这个问题已经有答案了: How to stop a setTimeout loop? (10 个回答) 已关闭 8 年前。 请帮助获得正确的函数或方法来停止 setTimeout 函数。 我一直在尝试
我正在运行一个多项目SBT(v0.13)构建,并且希望它在子项目中遇到的第一个错误(编译)时快速失败(停止)。 当前的行为是,当某项无法在子项目中进行编译时,构建将继续(以编译所有其他子项目)。 一旦
我有播放.wav文件中声音的代码,但是我无法停止播放歌曲,甚至无法退出程序直到播放结束。因为这是一首5分钟的歌曲,所以这是一个问题。这是我如何播放wav的代码: public class EasySo
我正在寻找一种解决方案,该如何控制从JSF应用程序播放音频文件。 我不需要完整的解决方案,只需引用我可以用来控制播放音频文件(开始/停止/更改声音)的组件即可。 我尝试搜索过去的问题,但没有成功。 我
我已经在test.ps1中编写了以下函数,在运行该脚本以启动/停止/ ..时我想做一个选择: function getState($SeviceName) { $server = @('hos
我必须设置一个 10 分钟的计时器,它会重定向到主屏幕。此外,它必须在每个操作(例如按下按钮)时重置。我找到了这个计时器:https://github.com/fengyuanchen/vue-cou
我正在制作一个聊天应用程序,功能之一就是发送声音。发送的HTML如下: LOL Stop Play 第一次发送时,“自动播放”效果很好。因此,现在我
我基本上希望页面能够接受用户输入的时间(以秒为单位)。 之后我希望当用户按下“开始”按钮时开始倒计时按下暂停按钮时“暂停”。还有一个重置按钮,以便用户可以从头开始倒计时。 这是我到目前为止得到的:
我需要停止 $.each 循环,加载图像,然后继续循环。我有 Canvas ,可以在其中加载对象图像。对象以正确的顺序排列在数组中。现在,当我尝试从数组加载对象时,存在一个问题:由于尺寸不同,并且它们
我是一名优秀的程序员,十分优秀!