Android
Учетные записи и учетные записи
Поиск…
Понимание пользовательских учетных записей / аутентификация
Следующий пример - это высокий уровень охвата ключевых концепций и базовой скелетной установки: -
- Собирает учетные данные от пользователя (обычно с созданного вами экрана входа в систему)
- Аутентификация учетных данных с сервером (сохранение пользовательской аутентификации)
- Сохраняет учетные данные на устройстве
Расширьте AbstractAccountAuthenticator (прежде всего, для получения аутентификации и повторной проверки подлинности)
public class AccountAuthenticator extends AbstractAccountAuthenticator {
@Override
public Bundle addAccount(AccountAuthenticatorResponse response, String accountType,
String authTokenType, String[] requiredFeatures, Bundle options) {
//intent to start the login activity
}
@Override
public Bundle confirmCredentials(AccountAuthenticatorResponse response, Account account, Bundle options) {
}
@Override
public Bundle editProperties(AccountAuthenticatorResponse response, String accountType) {
}
@Override
public Bundle getAuthToken(AccountAuthenticatorResponse response, Account account, String authTokenType,
Bundle options) throws NetworkErrorException {
//retrieve authentication tokens from account manager storage or custom storage or re-authenticate old tokens and return new ones
}
@Override
public String getAuthTokenLabel(String authTokenType) {
}
@Override
public Bundle hasFeatures(AccountAuthenticatorResponse response, Account account, String[] features)
throws NetworkErrorException {
//check whether the account supports certain features
}
@Override
public Bundle updateCredentials(AccountAuthenticatorResponse response, Account account, String authTokenType,
Bundle options) {
//when the user's session has expired or requires their previously available credentials to be updated, here is the function to do it.
}
}
Создайте службу (Framework Account Manager подключается к расширенному AbstractAccountAuthenticator через интерфейс службы)
public class AuthenticatorService extends Service {
private AccountAuthenticator authenticator;
@Override
public void onCreate(){
authenticator = new AccountAuthenticator(this);
}
@Override
public IBinder onBind(Intent intent) {
return authenticator.getIBinder();
}
}
Конфигурация XML аутентификатора (требуется инфраструктура менеджера учетных записей. Это то, что вы увидите внутри настроек -> Учетные записи в Android)
<account-authenticator xmlns:android="http://schemas.android.com/apk/res/android"
android:accountType="rename.with.your.applicationid"
android:icon="@drawable/app_icon"
android:label="@string/app_name"
android:smallIcon="@drawable/app_icon" />
Изменения в AndroidManifest.xml (объедините все вышеуказанные концепции, чтобы сделать его полезным для использования через AccountManager)
<application
...>
<service
android:name=".authenticator.AccountAuthenticatorService"
android:exported="false"
android:process=":authentication">
<intent-filter>
<action android:name="android.accounts.AccountAuthenticator"/>
</intent-filter>
<meta-data
android:name="android.accounts.AccountAuthenticator"
android:resource="@xml/authenticator"/>
</service>
</application>
В следующем примере будет показано, как использовать эту настройку.
Modified text is an extract of the original Stack Overflow Documentation
Лицензировано согласно CC BY-SA 3.0
Не связан с Stack Overflow