站长域名查询,WordPress超级链接不跳转,网站建设属于哪个经营范围,我想建个自己的网站文章目录 一、 账户同步二、 账户同步代码示例1、 账户同步 Service2、 账户同步 ContentProvider3、 AndroidManifest.xml 清单文件4、 sync-adapter 配置文件5、 账户同步工具类6、 MainActivity 启动账户同步7、 运行效果 三、 源码资源 一、 账户同步 账户同步的作用 : 如果… 文章目录 一、 账户同步二、 账户同步代码示例1、 账户同步 Service2、 账户同步 ContentProvider3、 AndroidManifest.xml 清单文件4、 sync-adapter 配置文件5、 账户同步工具类6、 MainActivity 启动账户同步7、 运行效果 三、 源码资源 一、 账户同步 账户同步的作用 : 如果应用的数据发生了改变 , 可以通过账户进行同步 , 进而与服务器进行数据同步操作 , 执行同步时 , 系统会拉活对应的应用进程 ;
进程拉活只是账户同步的附带作用 ; 账户同步时 , 需要应用中有对应的同步服务 , 系统也是通过 Binder 机制与应用进行同步操作 ; 账户同步需要在 账户同步服务 Service 中进行 , 定义一个 Service 进行账户同步 , 其 onBind 方法必须返回 AbstractThreadedSyncAdapter 的 getSyncAdapterBinder() 值 ;
账户同步需要自定义一个 AbstractThreadedSyncAdapter 类 , 并在 Service 中维护一个该类对象 ; class ThreadSyncAdapter extends AbstractThreadedSyncAdapter{public ThreadSyncAdapter(Context context, boolean autoInitialize) {super(context, autoInitialize);}public ThreadSyncAdapter(Context context, boolean autoInitialize,boolean allowParallelSyncs) {super(context, autoInitialize, allowParallelSyncs);}Overridepublic void onPerformSync(Account account, Bundle extras, String authority,ContentProviderClient provider, SyncResult syncResult) {// 账户同步操作// 与数据库 , 服务器同步操作 , 这里只是为了应用进程拉活 , 不实现具体的逻辑}}系统在进行账户同步的时候 , 会获取该 账户同步 Service 的 IBinder , 拿到该 IBinder 后 , 会调用 AbstractThreadedSyncAdapter 子类对象中的 onPerformSync 方法 , 执行同步操作 ;
该 onPerformSync 函数是系统在执行同步时执行的函数 , 但是这里我们的目的是为了拉活应用进程 , 并不是为了进行账户同步 , 这里空着就可以 ; 最后还要在清单文件中注册该同步 Service ; !-- 账户同步服务 --serviceandroid:name.account_service.AccountSyncServiceandroid:enabledtrueandroid:exportedtrueintent-filteraction android:nameandroid.content.SyncAdapter //intent-filtermeta-dataandroid:nameandroid.content.SyncAdapterandroid:resourcexml/sync_adapter //service除了同步 Service 组件之外 , 还必须有一个 ContentProvider 组件 , 系统进行账户同步时 , 会查找对应账户的 ContentProvider , 需要在应用中注册 ContentProvider , 还要与 同步 Service 进行关联 ;
关联的方法就是在 同步 Service 注册的清单文件中添加元数据 meta-data , 在 meta-data 标签下的 android:resource 属性中 , 指定账户同步的相关资源数据 sync-adapter , sync-adapter 标签中的 android:contentAuthority 属性就是指定的该 ContentProvider ;
?xml version1.0 encodingutf-8?
sync-adapterxmlns:androidhttp://schemas.android.com/apk/res/androidandroid:accountTypekeep_progress_alive.accountandroid:contentAuthoritykim.hsl.keep_progress_alive.providerandroid:allowParallelSyncsfalseandroid:isAlwaysSyncabletrueandroid:userVisiblefalse/sync-adapter 标签的 android:accountType 就是账户类型 , 与之前在 【Android 进程保活】应用进程拉活 ( 账户同步拉活 | 账号服务注册 | 源码资源 ) 博客注册的 account-authenticator 标签的 android:accountType 是一个值 ;
?xml version1.0 encodingutf-8?
account-authenticatorxmlns:androidhttp://schemas.android.com/apk/res/androidandroid:accountTypekeep_progress_alive.accountandroid:iconmipmap/ic_launcherandroid:labelstring/app_name /sync-adapter 标签的 android:isAlwaysSyncable 属性 , 表示该账户同步操作 , 是否总是同步 , 这里设置 true , 账户拉活 , 越频繁越好 ;
sync-adapter 标签的 android:userVisible 属性 , 表示是否在 设置 - 账号 界面 , 展示一个账户同步开关 , 这里选择 false , 不给用户展示 , 万一用户给关了 , 就无法进行账户拉活应用进程操作 ; 创建 ContentProvider , 然后在清单文件中注册 , 其中 provider 标签的 android:authorities 就是上述 sync-adapter 标签中的 android:contentAuthority 属性值 ; !-- 账户同步 ContentProvider --providerandroid:authoritieskim.hsl.keep_progress_alive.providerandroid:name.account_service.AccountSyncContentProvider /定义好账户同步 Service , ContentProvider , 并在清单文件中注册 ; 最后调用 ContentResolver 的 setIsSyncable 方法 , 设置账户同步开启 , //创建账户Account account new Account(kim.hsl, ACCOUNT_TYPE);// 设置账户同步开启// 注意 : 该操作西药权限 android.permission.WRITE_SYNC_SETTINGSContentResolver.setIsSyncable(account, kim.hsl.keep_progress_alive.provider, 1);调用 ContentResolver 的 setSyncAutomatically 方法 , 设置账户自动同步 , 注意 : 该操作需要权限 android.permission.WRITE_SYNC_SETTINGS ; // 设置账户自动同步ContentResolver.setSyncAutomatically(account, kim.hsl.keep_progress_alive.provider, true);调用 ContentResolver 的 setSyncAutomatically 方法 , 设置账户自动同步 , 最后一个参数是同步周期 , 这个值只是参考值, 系统并不会严格按照该值执行 , 一般情况下同步的间隔 10 分钟 ~ 1 小时 ; // 设置账户同步周期// 最后一个参数是同步周期 , 这个值只是参考值, 系统并不会严格按照该值执行// 一般情况下同步的间隔 10 分钟 ~ 1 小时ContentResolver.addPeriodicSync(account, kim.hsl.keep_progress_alive.provider, new Bundle(), 1);二、 账户同步代码示例 1、 账户同步 Service package kim.hsl.keep_progress_alive.account_service;import android.accounts.Account;
import android.app.Service;
import android.content.AbstractThreadedSyncAdapter;
import android.content.ContentProviderClient;
import android.content.Context;
import android.content.Intent;
import android.content.SyncResult;
import android.os.Bundle;
import android.os.IBinder;
import android.util.Log;public class AccountSyncService extends Service {// 账户同步 IBinder 对象private ThreadSyncAdapter mThreadSyncAdapter;public AccountSyncService() {}Overridepublic IBinder onBind(Intent intent) {return mThreadSyncAdapter.getSyncAdapterBinder();}Overridepublic void onCreate() {super.onCreate();mThreadSyncAdapter new ThreadSyncAdapter(getApplicationContext(), true);}class ThreadSyncAdapter extends AbstractThreadedSyncAdapter{public ThreadSyncAdapter(Context context, boolean autoInitialize) {super(context, autoInitialize);}public ThreadSyncAdapter(Context context, boolean autoInitialize,boolean allowParallelSyncs) {super(context, autoInitialize, allowParallelSyncs);}Overridepublic void onPerformSync(Account account, Bundle extras, String authority,ContentProviderClient provider, SyncResult syncResult) {// 账户同步操作// 与数据库 , 服务器同步操作 , 这里只是为了应用进程拉活 , 不实现具体的逻辑Log.i(AccountSyncService, 账户同步拉活激活);}}}2、 账户同步 ContentProvider package kim.hsl.keep_progress_alive.account_service;import android.content.ContentProvider;
import android.content.ContentValues;
import android.database.Cursor;
import android.net.Uri;import androidx.annotation.NonNull;
import androidx.annotation.Nullable;public class AccountSyncContentProvider extends ContentProvider {Overridepublic boolean onCreate() {return false;}NullableOverridepublic Cursor query(NonNull Uri uri, Nullable String[] projection, Nullable String selection, Nullable String[] selectionArgs, Nullable String sortOrder) {return null;}NullableOverridepublic String getType(NonNull Uri uri) {return null;}NullableOverridepublic Uri insert(NonNull Uri uri, Nullable ContentValues values) {return null;}Overridepublic int delete(NonNull Uri uri, Nullable String selection, Nullable String[] selectionArgs) {return 0;}Overridepublic int update(NonNull Uri uri, Nullable ContentValues values, Nullable String selection, Nullable String[] selectionArgs) {return 0;}
} 3、 AndroidManifest.xml 清单文件 ?xml version1.0 encodingutf-8?
manifest xmlns:androidhttp://schemas.android.com/apk/res/androidpackagekim.hsl.keep_progress_aliveuses-permission android:nameandroid.permission.FOREGROUND_SERVICE /uses-permissionandroid:nameandroid.permission.GET_ACCOUNTSandroid:maxSdkVersion22 /uses-permissionandroid:nameandroid.permission.AUTHENTICATE_ACCOUNTSandroid:maxSdkVersion22 /uses-permissionandroid:nameandroid.permission.WRITE_SYNC_SETTINGS/applicationandroid:allowBackuptrueandroid:iconmipmap/ic_launcherandroid:labelstring/app_nameandroid:roundIconmipmap/ic_launcher_roundandroid:supportsRtltrueandroid:themestyle/Theme.Keep_Progress_Aliveactivity android:name.MainActivityintent-filteraction android:nameandroid.intent.action.MAIN /category android:nameandroid.intent.category.LAUNCHER //intent-filter/activity!--设置最近任务列表中不显示该 Activity 组件 ( 不要被用户察觉 )android:excludeFromRecentstrue设置 Activity 亲和性让该界面在一个独立的任务栈中 , 不要与本应用的其它任务栈放在一起避免解除锁屏后 , 关闭 1 像素界面 , 将整个任务栈都唤醒android:taskAffinitykim.hsl.keep_progress_alive.alive--activityandroid:name.one_pixel_activity.OnePixelActivityandroid:excludeFromRecentstrueandroid:taskAffinitykim.hsl.keep_progress_alive.onepixelandroid:themestyle/OnePixelActivityTheme /!-- 用于提权的前台进程 --serviceandroid:name.foreground_service.ForegroundServiceandroid:enabledtrueandroid:exportedtrue /!-- 用于提权的前台进程, 关闭通知操作 --serviceandroid:name.foreground_service.CancelNotificationServiceandroid:enabledtrueandroid:exportedtrue /!-- 系统 Service 机制拉活 --serviceandroid:name.stick_service.StickServiceandroid:enabledtrueandroid:exportedtrue /!-- 用于账户同步拉活 --serviceandroid:name.account_service.AuthenticationServiceandroid:enabledtrueandroid:exportedtrueintent-filteraction android:nameandroid.accounts.AccountAuthenticator //intent-filtermeta-dataandroid:nameandroid.accounts.AccountAuthenticatorandroid:resourcexml/account_authenticator //service!-- 账户同步服务 --serviceandroid:name.account_service.AccountSyncServiceandroid:enabledtrueandroid:exportedtrueintent-filteraction android:nameandroid.content.SyncAdapter //intent-filtermeta-dataandroid:nameandroid.content.SyncAdapterandroid:resourcexml/sync_adapter //service!-- 账户同步 ContentProvider --providerandroid:authoritieskim.hsl.keep_progress_alive.providerandroid:name.account_service.AccountSyncContentProvider //application/manifest4、 sync-adapter 配置文件 ?xml version1.0 encodingutf-8?
sync-adapterxmlns:androidhttp://schemas.android.com/apk/res/androidandroid:accountTypekeep_progress_alive.accountandroid:contentAuthoritykim.hsl.keep_progress_alive.providerandroid:allowParallelSyncsfalseandroid:isAlwaysSyncabletrueandroid:userVisiblefalse/ 5、 账户同步工具类 package kim.hsl.keep_progress_alive.account_service;import android.accounts.Account;
import android.accounts.AccountManager;
import android.annotation.SuppressLint;
import android.content.ContentResolver;
import android.content.Context;
import android.os.Bundle;public class AccountUtils {/*** 添加账户类型* 在 account-authenticator xml 标签中的 android:accountType 属性中定义的*/public static final String ACCOUNT_TYPE keep_progress_alive.account;/*** 添加账户* param context*/public static void addAccount (Context context){AccountManager accountManager (AccountManager) context.getSystemService(Context.ACCOUNT_SERVICE);// 需要使用 android.permission.GET_ACCOUNTS 权限Account[] accounts accountManager.getAccounts();// 该类型账号不为空if (accounts.length 0){// 账户已存在 , 不进行处理}else{//创建账户Account account new Account(kim.hsl, ACCOUNT_TYPE);// 添加一个新账户accountManager.addAccountExplicitly(account, 123456, new Bundle());}}/*** 告知系统开始自动同步*/public static void autoSyncStart(){//创建账户Account account new Account(kim.hsl, ACCOUNT_TYPE);// 设置账户同步开启// 注意 : 该操作需要权限 android.permission.WRITE_SYNC_SETTINGSContentResolver.setIsSyncable(account, kim.hsl.keep_progress_alive.provider, 1);// 设置账户自动同步ContentResolver.setSyncAutomatically(account, kim.hsl.keep_progress_alive.provider, true);// 设置账户同步周期// 最后一个参数是同步周期 , 这个值只是参考值, 系统并不会严格按照该值执行// 一般情况下同步的间隔 10 分钟 ~ 1 小时ContentResolver.addPeriodicSync(account, kim.hsl.keep_progress_alive.provider, new Bundle(), 1);}} 6、 MainActivity 启动账户同步 package kim.hsl.keep_progress_alive;import androidx.appcompat.app.AppCompatActivity;import android.content.Intent;
import android.os.Bundle;import kim.hsl.keep_progress_alive.account_service.AccountUtils;
import kim.hsl.keep_progress_alive.foreground_service.ForegroundService;
import kim.hsl.keep_progress_alive.one_pixel_activity.KeepProgressAliveManager;
import kim.hsl.keep_progress_alive.stick_service.StickService;public class MainActivity extends AppCompatActivity {Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);// 1. 1 像素 Activity 提升应用权限// 注册广播接收者 , 1 像素 Activity 启动的 广播接收者//KeepProgressAliveManager.getmInstance().registerReceiver(this);// 2. 通过前台 Service 提升应用权限// 启动普通 Service , 但是在该 Service 的 onCreate 方法中执行了 startForeground// 变成了前台 Service 服务//startService(new Intent(this, ForegroundService.class));// 3. 使用 Service 机制拉活//startService(new Intent(this, StickService.class));// 4. 账户同步拉活AccountUtils.addAccount(this);// 开始同步AccountUtils.autoSyncStart();}Overrideprotected void onDestroy() {super.onDestroy();// 1. 取消注册广播接收者, 也可以不取消注册//KeepProgressAliveManager.getmInstance().registerReceiver(this);}
}7、 运行效果 在 Android 10.0 原生系统中 , 等待 15 分钟左右 , 没有拉起应用进程 ; 三、 源码资源 源码资源 :
GitHub 地址 : https://github.com/han1202012/Keep_Progress_AliveCSDN 源码快照 : https://download.csdn.net/download/han1202012/16607754