AbstractThreadedSyncAdapterを使用して、ローカルデータベースをサーバーと同期しようとしています。私は見つけたガイドに従いましたが、それを機能させることができません。Android2.2用です。
オーセンティケーターシステムが機能しています。AccountAuthenticatorActivityで、アカウントを作成した後、次のことを行います。
Bundle params = new Bundle();
params.putBoolean(ContentResolver.SYNC_EXTRAS_EXPEDITED, false);
params.putBoolean(ContentResolver.SYNC_EXTRAS_DO_NOT_RETRY, false);
params.putBoolean(ContentResolver.SYNC_EXTRAS_MANUAL, false);
ContentResolver.addPeriodicSync(account, "com.syncal.authority", params, 30);
ContentResolver.setSyncAutomatically(account, "com.syncal.authority", true);
ContentResolver.requestSync(account,"com.syncal.authority",params);
SyncServiceを作成し、マニフェストで宣言します。いくつかの機能:
@Override
public IBinder onBind(Intent intent) {
Log.i(TAG, "inBind() " + intent.getAction());
return getSyncAdapter().getSyncAdapterBinder();
}
private synchronized AbstractThreadedSyncAdapter getSyncAdapter() {
Log.i(TAG, "getSyncAdapter()");
if (mSyncAdapter == null) {
mSyncAdapter = new SweetSyncAdapter(this, true);
}
return mSyncAdapter;
}
次に、SyncAdapterを実装しました。onPerformSync関数は空です。呼び出されたかどうかを知りたいだけですが、呼び出されることはありません。
public class SweetSyncAdapter extends AbstractThreadedSyncAdapter {
Context mContext;
private String AUTH_TOKEN_TYPE;
private AccountManager mAccountManager;
private String mAuthToken;
private final String TAG = "SweetContactSync";
static final String LAST_SYNC_KEY = "lastSync";
public SweetSyncAdapter(Context context, boolean autoInitialize) {
super(context, autoInitialize);
Log.i(TAG, "SweetSyncAdapter");
mContext = context;
AUTH_TOKEN_TYPE = mContext.getString(R.string.account_type);
mAccountManager = AccountManager.get(mContext);
}
public interface ISugarRunnable {
public void run() throws URISyntaxException, OperationCanceledException, AuthenticatorException, IOException,
AuthenticationException;
}
class SugarRunnable implements Runnable {
ISugarRunnable r;
Account mAccount;
SyncResult mSyncResult;
public SugarRunnable(Account acc, SyncResult syncResult, ISugarRunnable _r) {
r = _r;
mAccount = acc;
mSyncResult = syncResult;
}
public void run() {
try {
r.run();
} catch ... //All the catchs
}
}
@Override
public void onPerformSync(final Account account, Bundle extras, String authority,
ContentProviderClient provider, SyncResult syncResult) {
Log.i(TAG, "onPerformSync()");
}
}
私のxml/sync_adapter.xmlには次のコードがあります。
<?xml version="1.0" encoding="utf-8"?>
<sync-adapter xmlns:android="http://schemas.android.com/apk/res/android"
android:contentAuthority="com.syncal.authority"
android:accountType="com.syncal.account"
/>
マニフェストのサービス部分は次のとおりです。
<service android:name=".sweet.SweetSyncService" android:exported="true"
android:label="@string/app_name">
<intent-filter>
<action android:name="android.content.SyncAdapter" />
</intent-filter>
<meta-data android:name="android.content.SyncAdapter"
android:resource="@xml/sync_adapter" />
</service>
私が従ったガイドがそれが必要であると言って、マニフェストでもそれを宣言したので、私は自分のContentProviderを作成しました(関数は空で、ログに書き込むだけです)が、どの関数も呼び出されません。
onPerformSync関数が呼び出されない理由を誰かが知っていますか?SweetSyncServiceのonBind関数が呼び出され、SweetSyncAdapterが作成されますが、これ以降、ログにメッセージが表示されません。
読んでくれてありがとう、私はたくさんのコードをタイプしたことを知っています、しかし私はそれをしばらくの間取り組んできました、そして私はそれを修正することができません。