- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试在 Android 上使用 AccountManager.addAccount()
添加自定义帐户。我在关注 this tutorial .当我尝试使用 AccountManagerCallback
的 run
方法获得结果时,我得到 AuthenticatorException
消息:android.accounts.AuthenticatorException: bind失败
。
经过一些研究,我找到了两个可能的解决方案,但我已经declared authenticator在 application
标签内,和 checked my account type .我还将 list 权限与教程中的 list 权限进行了比较。我正在使用 android studio 1.4,我在多个模拟器和物理设备上进行了尝试。
这是我的 AndroidManifest.xml
,还有 authenticator.xml
和 account_preferences.xml
:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.test.myproject" >
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.USE_CREDENTIALS" />
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<uses-permission android:name="android.permission.READ_PROFILE" />
<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.AUTHENTICATE_ACCOUNTS"/>
<uses-permission android:name="android.permission.MANAGE_ACCOUNTS"/>
<application
android:allowBackup="true"
android:icon="@mipmap/test_logo"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name=".view.MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name=".view.LoginActivity"
android:label="@string/app_name">
</activity>
<service
android:name="com.test.myproject.model.utility.MyAuthenticatorService">
<intent-filter>
<action android:name="android.accounts.AccountAuthenticator"/>
</intent-filter>
<meta-data
android:name="android.accounts.AccountAuthenticator"
android:resource="@xml/authenticator" />
</service>
<meta-data
android:name="com.google.android.gms.version"
android:value="@integer/google_play_services_version" />
</application>
</manifest>
我也试过命名服务 .model.utility.MyAuthenticatorService
但没有效果。
validator .xml:
<?xml version="1.0" encoding="utf-8"?>
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">
<account-authenticator xmlns:android="http://schemas.android.com/apk/res/android"
android:accountType="com.test.myproject"
android:icon="@drawable/test_logo"
android:smallIcon="@drawable/test_logo"
android:label="@string/not_implemented"
android:accountPreferences="@xml/account_preferences"
/>
</PreferenceScreen>
account_preferences.xml:
<?xml version="1.0" encoding="utf-8"?>
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">
<PreferenceCategory android:title="@string/not_implemented" />
<CheckBoxPreference android:title="Use debug server"
android:key="isDebug"
android:summary="Connecting to a debug server instead of prod server"/>
<SwitchPreference android:title="Debug Logs" android:key="logsVerbose" android:summary="Show debug logs on LogCat"/>
</PreferenceScreen>
这是MyAuthenticatorService
:
public class MyAuthenticatorService extends Service {
@Nullable
@Override
public IBinder onBind(Intent intent) {
MyAuthenticator myAuthenticator = new MyAuthenticator(this);
return myAuthenticator.getIBinder();
}
}
这是MyAuthenticator
:
public class MyAuthenticator extends AbstractAccountAuthenticator {
private Context context;
public MyAuthenticator(Context context) {
super(context);
this.context = context;
}
@Override
public Bundle addAccount(AccountAuthenticatorResponse response, String accountType, String authTokenType, String[] requiredFeatures, Bundle options) throws NetworkErrorException {
final Intent intent = new Intent(context, LoginActivity.class);
intent.putExtra(LoginActivity.ARG_ACCOUNT_TYPE, accountType);
intent.putExtra(LoginActivity.ARG_AUTH_TYPE, authTokenType);
intent.putExtra(LoginActivity.ARG_IS_ADDING_NEW_ACCOUNT, true);
intent.putExtra(AccountManager.KEY_ACCOUNT_AUTHENTICATOR_RESPONSE, response);
final Bundle bundle = new Bundle();
bundle.putParcelable(AccountManager.KEY_INTENT, intent);
return bundle;
}
//other override methods (they all return null for now)
}
这里是 MainActivity
:
public class MainActivity extends AppCompatActivity {
private Toolbar toolbar;
private NavigationView navigationView;
private DrawerLayout drawerLayout;
private SharedPreferences sharedPreferences;
private AccountManager accountManager;
private static final String ACCOUNT_TYPE = "com.test.myproject";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_drawer);
this.accountManager = AccountManager.get(this);
signIn(ACCOUNT_TYPE, "access_token");
//other stuff
}
private void signIn(String accountType, String authTokenType) {
final AccountManagerFuture<Bundle> future = accountManager.addAccount(ACCOUNT_TYPE, authTokenType, null, null, this, new AccountManagerCallback<Bundle>() {
@Override
public void run(AccountManagerFuture<Bundle> future) {
try {
Bundle bnd = future.getResult();
showMessage("Account was created");
Log.d("udinic", "AddNewAccount Bundle is " + bnd);
} catch (Exception e) {
e.printStackTrace();
showMessage(e.getMessage());
}
}
}, null);
}
}
调试时,在 Bundle bnd = future.getResult();
上抛出错误,并且 future 具有状态 3 和结果 android.accounts.AuthenticatorException: bind failure
。艰难的执行永远不会到达 LoginActivity,或者至少不会触发断点,这里是:
public class LoginActivity extends AccountAuthenticatorActivity {
public final static String ARG_ACCOUNT_TYPE = "ACCOUNT_TYPE";
public final static String ARG_ACCOUNT_NAME = "AUTH_TYPE";
public final static String ARG_AUTH_TYPE = "ACCOUNT_NAME";
public final static String PARAM_USER_PASS = "USER_PASS";
private AccountManager accountManager;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_login);
this.accountManager = AccountManager.get(getBaseContext());
}
public void login(View view) {
EditText usernameEditText = (EditText)findViewById(R.id.textLoginUsername);
EditText passwordEditText = (EditText)findViewById(R.id.textLoginPassword);
String ownerUsername = usernameEditText.getText().toString();
String ownerPassword = passwordEditText.getText().toString();
String clientId = "test";
String clientSecret = "test";
AccountManager manager = AccountManager.get(this);
TokenRequestTask tokenRequestTask = new TokenRequestTask();
tokenRequestTask.execute(ownerUsername, ownerPassword, clientId, clientSecret);
}
private class TokenRequestTask extends AsyncTask<String, Void, Intent> {
@Override
protected Intent doInBackground(String... params) {
final String accountType = getIntent().getStringExtra(ARG_ACCOUNT_TYPE);
String ownerUsername = params[0];
String ownerSecret = params[1];
String clientId = params[2];
String clientSecret = params[3];
String authToken = signIn(clientId, clientSecret, ownerUsername, ownerSecret, "password");
Bundle resultData = new Bundle();
resultData.putString(AccountManager.KEY_ACCOUNT_NAME, ownerUsername);
resultData.putString(AccountManager.KEY_ACCOUNT_TYPE, accountType);
resultData.putString(AccountManager.KEY_AUTHTOKEN, authToken);
resultData.putString(PARAM_USER_PASS, ownerSecret);
final Intent resultIntent = new Intent();
resultIntent.putExtras(resultData);
return resultIntent;
}
}
private String signIn(String clientId, String clientSecret, String ownerUsername, String ownerSecret, String grantType) {
MyApi20ServiceImpl service = (MyApi20ServiceImpl)new ServiceBuilder().provider(MyApi20.class)
.apiKey(clientId)
.apiSecret(clientSecret)
.signatureType(SignatureType.QueryString)
.build();
Token token = service.getAccessToken(ownerUsername, ownerSecret, grantType);
return token.getToken();
}
}
这是完整的堆栈跟踪:
10-19 10:39:05.042 25931-25931/? I/art: Not late-enabling -Xcheck:jni (already on)
10-19 10:39:05.042 25931-25931/? I/art: Late-enabling JIT
10-19 10:39:05.068 25931-25931/? I/art: JIT created with code_cache_capacity=2MB compile_threshold=1000
10-19 10:39:05.118 25931-25931/com.test.myproject W/System: ClassLoader referenced unknown path: /data/app/com.test.myproject-1/lib/x86
10-19 10:39:05.355 25931-25960/com.test.myproject D/OpenGLRenderer: Use EGL_SWAP_BEHAVIOR_PRESERVED: true
10-19 10:39:05.358 25931-25931/com.test.myproject D/: HostConnection::get() New Host Connection established 0xad974e50, tid 25931
10-19 10:39:05.366 25931-25931/com.test.myproject W/System.err: android.accounts.AuthenticatorException: bind failure
10-19 10:39:05.366 25931-25931/com.test.myproject W/System.err: at android.accounts.AccountManager.convertErrorToException(AccountManager.java:2147)
10-19 10:39:05.366 25931-25931/com.test.myproject W/System.err: at android.accounts.AccountManager.-wrap0(AccountManager.java)
10-19 10:39:05.366 25931-25931/com.test.myproject W/System.err: at android.accounts.AccountManager$AmsTask$Response.onError(AccountManager.java:1990)
10-19 10:39:05.366 25931-25931/com.test.myproject W/System.err: at android.accounts.IAccountManagerResponse$Stub.onTransact(IAccountManagerResponse.java:69)
10-19 10:39:05.366 25931-25931/com.test.myproject W/System.err: at android.os.Binder.execTransact(Binder.java:453)
10-19 10:39:05.423 25931-25960/com.test.myproject D/: HostConnection::get() New Host Connection established 0xac17e080, tid 25960
10-19 10:39:05.433 25931-25960/com.test.myproject I/OpenGLRenderer: Initialized EGL, version 1.4
10-19 10:39:05.538 25931-25960/com.test.myproject W/EGL_emulation: eglSurfaceAttrib not implemented
10-19 10:39:05.538 25931-25960/com.test.myproject W/OpenGLRenderer: Failed to set EGL_SWAP_BEHAVIOR on surface 0xaf125cc0, error=EGL_SUCCESS
10-19 10:39:05.903 25931-25931/com.test.myproject I/Choreographer: Skipped 31 frames! The application may be doing too much work on its main thread.
10-19 10:39:05.975 25931-25960/com.test.myproject W/EGL_emulation: eglSurfaceAttrib not implemented
10-19 10:39:05.975 25931-25960/com.test.myproject W/OpenGLRenderer: Failed to set EGL_SWAP_BEHAVIOR on surface 0xb3fe0c40, error=EGL_SUCCESS
10-19 10:39:07.392 25931-25960/com.test.myproject E/Surface: getSlotFromBufferLocked: unknown buffer: 0xac027c50
有人可以帮我解决这个问题吗?
最佳答案
好吧,那真的是复制粘贴错误,把我搞疯了。在 authenticator.xml
:
<?xml version="1.0" encoding="utf-8"?>
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">
<account-authenticator xmlns:android="http://schemas.android.com/apk/res/android"
android:accountType="com.test.myproject"
android:icon="@drawable/test_logo"
android:smallIcon="@drawable/test_logo"
android:label="@string/not_implemented"
android:accountPreferences="@xml/account_preferences"
/>
</PreferenceScreen>
</PreferenceScreen>
不应该在这里。
如果您收到此错误,请检查您的 xml 文件。
关于java - Android AccountManager 抛出 AuthenticatorException : bind failure when adding account,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33165552/
来自 java docs 公共(public) FileWriter(String fileName) 抛出 IOException 抛出: IOException - 如果指定的文件存在但它是目录而
我使用以下代码将我的 .net 客户端(基于 CQL)连接到 3 节点 Cassandra 集群。我以 30 条记录/秒的速度(从 RabbitMQ)获取数据,并且它们顺利地存储在 cassandra
如果在读取文件时缺少字段,我应该捕获 NoSuchElementException。如果缺少一个字段,我只需要跳到文件的下一行。我的问题是,我在哪里实现我的 try/catch 代码来做到这一点?这是
我正在尝试使用 ASP.NET MVC 实现 OpeinID 登录。我正在尝试按照 http://blog.nerdbank.net/2008/04/add-openid-login-support-
学习使用 Java 进行 xml 解析,并且正在编写一个测试程序来尝试各种东西。所有测试 System.out.println() 都是我在控制台中所期望的,除了 childElement 返回 [n
我正在尝试使用 SwingUtilities 创建 JFrame Thread tt = new Thread(new Runnable() { public void run
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
我写了这段代码: MethodInfo method2 = typeof(IntPtr).GetMethod( "op_Explicit", Bind
我开始学习 Java,并且正在根据书本做一些练习。在执行此操作时,我遇到了以下错误:线程“main”java.util.InputMismatchException 中出现异常。我正在编写一个简单的程
我有一个文本文件,其中前两行是整数 m 和 n,然后有 m 行,每行都有 n 管道分隔值。我编写了一个程序,读取文件并使用文件中的值创建 m*n 数组,它工作了无数次,然后突然,使用相同的代码,使用相
所以我尝试使用在另一个类中生成的 bean 以在主应用程序中使用 package com.simon.spring.basics.properties; import org.spri
我还没有完成这个应用程序,但我希望在我的手机上看到它的样子。但是,它会强制关闭并引发 InstantiationException。 logcat 异常: 09-19 20:13:47.987: D/
我想从 UIViewController 加载一个基于 SwiftUI 的 View ,该 View 读取包本地的 json。仅 swiftUI 项目中的代码和绑定(bind)工作正常,当我利用 UI
'java.net.SocketTimeoutException:连接超时' 循环一段时间后我收到此错误。为什么我会收到 SocketTimeoutException?我该如何修复这个错误? @Ove
当有 null 值时抛出 ArgumentNullException() 是个好主意吗? This thread 没有提到在 null 上抛出的最明显的异常。 谢谢 最佳答案 ArgumentNull
我得到这个异常: NullReferenceException Object reference not set to an instance of an object at Namespace
所以其中一个方法的描述如下: public BasicLinkedList addToFront(T data) This operation is invalid for a sorted list
我正在使用 Intellij Idea,当我去生成 JavaDocs(通过工具 -> 生成 JavaDoc)时,我抛出了一个 IllegealArgumentException,没有关于发生了什么问题
我正在学习 C++ 中的互斥锁,但以下代码(摘自 N. Josuttis 的“C++ 标准库”)有问题。 我不明白为什么它会阻塞/抛出除非我在主线程中添加this_thread::sleep_for(
我正在试验 JavaFX 标签和组,通过鼠标拖动将它们移动到屏幕上。新节点从一些线程添加到动画组。但是,有时我会突然看到以下异常 - 我假设,当某些节点重叠时。但是不知道是什么问题……因为不涉及我的代
我是一名优秀的程序员,十分优秀!