Android中怎么創(chuàng)建自己的內(nèi)容提供器

本文小編為大家詳細(xì)介紹“Android中怎么創(chuàng)建自己的內(nèi)容提供器”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“Android中怎么創(chuàng)建自己的內(nèi)容提供器”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識吧。

創(chuàng)新互聯(lián)公司是專業(yè)的涇縣網(wǎng)站建設(shè)公司,涇縣接單;提供網(wǎng)站設(shè)計、做網(wǎng)站,網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行涇縣網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊,希望更多企業(yè)前來合作!

創(chuàng)建內(nèi)容提供器的步驟

前面已經(jīng)提到過,如果想要實現(xiàn)跨程序共享數(shù)據(jù)的功能,官方推薦的方式就是使用內(nèi)容提供器,可以通過新建一個類去繼承 ContentProvider 的方式來創(chuàng)建一個自己的內(nèi)容提供器。 ContentProvider 類中有六個抽象方法,我們在使用子類繼承它的時候,需要將這六個方法全 部重寫。新建 MyProvider 繼承自 ContentProvider,代碼如下所示:

public class MyProvider extends ContentProvider {
@Override
public boolean onCreate() {
return false;
}
@Override
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {
return null;
}
@Override
public Uri insert(Uri uri, ContentValues values) {
return null;
}
@Override
public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) {
return 0;
}
@Override
public int delete(Uri uri, String selection, String[] selectionArgs) {
return 0;
}
@Override
public String getType(Uri uri) {
return null;
}
}

在這六個方法中,相信大多數(shù)你都已經(jīng)非常熟悉了,我再來簡單介紹一下吧。

1.    onCreate()

初始化內(nèi)容提供器的時候調(diào)用。通常會在這里完成對數(shù)據(jù)庫的創(chuàng)建和升級等操作, 返回 true 表示內(nèi)容提供器初始化成功,返回 false 則表示失敗。注意,只有當(dāng)存在 ContentResolver 嘗試訪問我們程序中的數(shù)據(jù)時,內(nèi)容提供器才會被初始化。

2.    query()

從內(nèi)容提供器中查詢數(shù)據(jù)。使用 uri 參數(shù)來確定查詢哪張表,projection 參數(shù)用于確 定查詢哪些列,selection 和 selectionArgs 參數(shù)用于約束查詢哪些行,sortOrder 參數(shù)用于 對結(jié)果進(jìn)行排序,查詢的結(jié)果存放在 Cursor 對象中返回。

3.    insert()

向內(nèi)容提供器中添加一條數(shù)據(jù)。使用 uri 參數(shù)來確定要添加到的表,待添加的數(shù)據(jù) 保存在 values 參數(shù)中。添加完成后,返回一個用于表示這條新記錄的 URI。

4.    update()

更新內(nèi)容提供器中已有的數(shù)據(jù)。使用 uri 參數(shù)來確定更新哪一張表中的數(shù)據(jù),新數(shù) 據(jù)保存在 values 參數(shù)中,selection 和 selectionArgs 參數(shù)用于約束更新哪些行,受影響的 行數(shù)將作為返回值返回。

5.    delete()

從內(nèi)容提供器中刪除數(shù)據(jù)。使用 uri 參數(shù)來確定刪除哪一張表中的數(shù)據(jù),selection和 selectionArgs 參數(shù)用于約束刪除哪些行,被刪除的行數(shù)將作為返回值返回。

6.    getType()

根據(jù)傳入的內(nèi)容 URI 來返回相應(yīng)的 MIME 類型。 可以看到,幾乎每一個方法都會帶有 Uri 這個參數(shù),這個參數(shù)也正是調(diào)用 ContentResolver的增刪改查方法時傳遞過來的。而現(xiàn)在,我們需要對傳入的 Uri 參數(shù)進(jìn)行解析,從中分析出 調(diào)用方期望訪問的表和數(shù)據(jù)。

回顧一下,一個標(biāo)準(zhǔn)的內(nèi)容 URI 寫法是這樣的:

content://com.example.app.provider/table1

這就表示調(diào)用方期望訪問的是 com.example.app 這個應(yīng)用的 table1 表中的數(shù)據(jù)。除此之 外,我們還可以在這個內(nèi)容 URI 的后面加上一個 id,如下所示:

content://com.example.app.provider/table1/1

這就表示調(diào)用方期望訪問的是 com.example.app 這個應(yīng)用的 table1 表中 id 為 1 的數(shù)據(jù)。 內(nèi)容 URI 的格式主要就只有以上兩種,以路徑結(jié)尾就表示期望訪問該表中所有的數(shù)據(jù),以 id 結(jié)尾就表示期望訪問該表中擁有相應(yīng) id 的數(shù)據(jù)。我們可以使用通配符的方式來分別匹 配這兩種格式的內(nèi)容 URI,規(guī)則如下。

1.    *:表示匹配任意長度的任意字符

2.    #:表示匹配任意長度的數(shù)字 所以,一個能夠匹配任意表的內(nèi)容 URI 格式就可以寫成:

content://com.example.app.provider/*

而一個能夠匹配 table1 表中任意一行數(shù)據(jù)的內(nèi)容 URI 格式就可以寫成:

content://com.example.app.provider/table1/#

接著,我們再借助 UriMatcher 這個類就可以輕松地實現(xiàn)匹配內(nèi)容 URI 的功能。UriMatcher 中提供了一個 addURI()方法,這個方法接收三個參數(shù),可以分別把權(quán)限、路徑和一個自定義 代碼傳進(jìn)去。這樣,當(dāng)調(diào)用 UriMatcher 的 match()方法時,就可以將一個 Uri 對象傳入,返 回值是某個能夠匹配這個 Uri 對象所對應(yīng)的自定義代碼,利用這個代碼,我們就可以判斷出 調(diào)用方期望訪問的是哪張表中的數(shù)據(jù)了。修改 MyProvider 中的代碼,如下所示:

public class MyProvider extends ContentProvider {
public static final int TABLE1_DIR = 0;
public static final int TABLE1_ITEM = 1;
public static final int TABLE2_DIR = 2;
public static final int TABLE2_ITEM = 3;
private static UriMatcher uriMatcher; static {
uriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
uriMatcher.addURI("com.example.app.provider", "table1", TABLE1_DIR);
uriMatcher.addURI("com.example.app.provider ", "table1/#", TABLE1_ITEM);
uriMatcher.addURI("com.example.app.provider ", "table2", TABLE2_ITEM);
uriMatcher.addURI("com.example.app.provider ", "table2/#", TABLE2_ITEM);
}
……
@Override
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {
switch (uriMatcher.match(uri)) {
case TABLE1_DIR:
// 查詢table1表中的所有數(shù)據(jù)
break;
case TABLE1_ITEM:
// 查詢table1表中的單條數(shù)據(jù)
break;
case TABLE2_DIR:
// 查詢table2表中的所有數(shù)據(jù)
break;
case TABLE2_ITEM:
// 查詢table2表中的單條數(shù)據(jù)
break;
default:
break;
}
……
}
……
}

可以看到,MyProvider 中新增了四個整型常量,其中 TABLE1_DIR 表示訪問 table1 表 中的所有數(shù)據(jù),TABLE1_ITEM 表示訪問 table1 表中的單條數(shù)據(jù),TABLE2_DIR 表示訪問 table2 表中的所有數(shù)據(jù),TABLE2_ITEM 表示訪問 table2 表中的單條數(shù)據(jù)。接著在靜態(tài)代碼 塊里我們創(chuàng)建了 UriMatcher 的實例,并調(diào)用 addURI()方法,將期望匹配的內(nèi)容 URI 格式傳 遞進(jìn)去,注意這里傳入的路徑參數(shù)是可以使用通配符的。然后當(dāng) query()方法被調(diào)用的時候, 就會通過 UriMatcher 的 match()方法對傳入的 Uri 對象進(jìn)行匹配,如果發(fā)現(xiàn) UriMatcher 中某 個內(nèi)容 URI 格式成功匹配了該 Uri 對象,則會返回相應(yīng)的自定義代碼,然后我們就可以判斷 出調(diào)用方期望訪問的到底是什么數(shù)據(jù)了。

上述代碼只是以 query()方法為例做了個示范,其實 insert()、update()、delete()這幾個方 法的實現(xiàn)也是差不多的,它們都會攜帶 Uri 這個參數(shù),然后同樣利用 UriMatcher 的 match() 方法判斷出調(diào)用方期望訪問的是哪張表,再對該表中的數(shù)據(jù)進(jìn)行相應(yīng)的操作就可以了。

除此之外,還有一個方法你會比較陌生,即 getType()方法。它是所有的內(nèi)容提供器都必 須提供的一個方法,用于獲取 Uri 對象所對應(yīng)的 MIME 類型。一個內(nèi)容 URI 所對應(yīng)的 MIME 字符串主要由三部分組分,Android 對這三個部分做了如下格式規(guī)定。

1.    必須以 vnd 開頭。
2.    如果內(nèi)容 URI 以路徑結(jié)尾,則后接 android.cursor.dir/,如果內(nèi)容 URI 以 id 結(jié)尾, 則后接 android.cursor.item/。
3.    最后接上 vnd.<authority>.<path>。
所以,對于 content://com.example.app.provider/table1 這個內(nèi)容 URI,它所對應(yīng)的 MIME

類型就可以寫成:

vnd.android.cursor.dir/vnd.com.example.app.provider.table1

對于 content://com.example.app.provider/table1/1 這個內(nèi)容 URI,它所對應(yīng)的 MIME 類型 就可以寫成:

vnd.android.cursor.item/vnd. com.example.app.provider.table1

現(xiàn)在我們可以繼續(xù)完善 MyProvider 中的內(nèi)容了,這次來實現(xiàn) getType()方法中的邏輯, 代碼如下所示:

public class MyProvider extends ContentProvider {
……
@Override
public String getType(Uri uri) { switch (uriMatcher.match(uri)) { case TABLE1_DIR:
return "vnd.android.cursor.dir/vnd.com.example.app.provider.
table1";
case TABLE1_ITEM:
return "vnd.android.cursor.item/vnd.com.example.app.provider.
table1";
case TABLE2_DIR:
return "vnd.android.cursor.dir/vnd.com.example.app.provider.
table2";
case TABLE2_ITEM:
return "vnd.android.cursor.item/vnd.com.example.app.provider.
table2";
default:
break;
}
return null;
}
}

讀到這里,這篇“Android中怎么創(chuàng)建自己的內(nèi)容提供器”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領(lǐng)會,如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

當(dāng)前名稱:Android中怎么創(chuàng)建自己的內(nèi)容提供器
文章URL:http://bm7419.com/article16/jcssgg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)建站網(wǎng)站導(dǎo)航、ChatGPT、網(wǎng)站改版商城網(wǎng)站、軟件開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)