第一行代码学习笔记:跨程序共享数据----内容提供器

简介

内容提供器主要用在不同程序之间实现数据共享的功能,它提供了一套完整的机制,允许一个程序访问另一个程序中的数据,同时还能保证被访问数据的安全性。目前,使用内容提供器是Android实现跨程序数据共享的标准方式。内容提供器可以选择只对哪一部分数据进行共享,从而保证我们程序中的隐私数据不会有泄漏的风险。

访问其他程序中的数据

ContentResolver的基本用法

想要访问内容提供器中的共享数据,一定要借助ContentResolver类,可以通过Context中的getContentResolver方法获取该类的实例。ContentResolver中提供了一系列方法对数据进行增删改查操作,ContentResolver中的增删改查方法都不接收表名参数,而是使用一个Url参数代替。这个Url称为内容URI,内容URI给内容提供器中的数据建立了唯一标识符,主要由两部分组成:authority和path。

authority是用于对不同的应用程序做区分的,一般会采用包名来进行命名,比如包名为com.zsp.runtimepermissiontest,authority就可以命名为com.zsp.runtimepermissiontest.provider.

path则是对用于对同一应用程序中不同的表做区分的,通常会添加到authority后面。某个数据库中存在table表,内容URI的标准格式为content://com.zsp.runtimepermissiontest.provider/table

在得到了URI后还需要将它解析成Uri对象才可以作为参数传入

Uri uri = Uri.parse("content://com.zsp.runtimepermissiontest.provider/table");

现在就可以用这个Uri对象来查询table表中的数据了

uri:指定查询某个应用程序下的某一张表

projrction:指定查询的列名

selection:指定where的约束条件

selectionArgs:为where中的占位符提供具体的值

sortOlder:指定查询结果否认排列方式。

Cursor cursor = getContentResolver().query(uri,projection,selection,selectionArgs,sortOlder);

遍历

if (cursor!=null){
                while (cursor.moveToNext()){
                    String column1 = cursor.getString(cursor.getColumnIndex("column1"));
                    int column2 = cursor.getInt(cursor.getColumnIndex("column2"));
                }
                cursor.close();
            }

添加数据

 ContentValues values = new ContentValues();
            values.put("column1","text");
            values.put("column2",1);
            getContentResolver().insert(uri,values);

更新这条数据把column1清空

ContentValues values = new ContentValues();
            values.put("column1","");
            getContentResolver().update(uri,values,"column1 = ? and column2 =?",new String[]{"text","1"});

删除

 getContentResolver().delete(uri,"column2 =?",new String[]{"1"});

创建自己的内容提供器

通过新建一个类去继承ContentProvider的方式来创建自己的内容提供器。

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.zsp.runtimepermissiontest.provider", "table1", TABLE1_DIR);
        uriMatcher.addURI("com.zsp.runtimepermissiontest.provider", "table1/#", TABLE1_ITEM);
        uriMatcher.addURI("com.zsp.runtimepermissiontest.provider", "table2", TABLE2_DIR);
        uriMatcher.addURI("com.zsp.runtimepermissiontest.provider", "table2/#", TABLE2_ITEM);
    }

    /**
     * 初始化内容提供器的时候调用,通常会在这里完成对数据库的创建和升级等操作,返回true表示内容提供器创建成功,
     * 返回false表示失败,只有当ContentResolver尝试访问我们程序中的数据时,内容提供器才会被初始化
     *
     * @return
     */
    @Override
    public boolean onCreate() {
        return false;
    }

    /**
     * @param uri          确定查询哪张表
     * @param projetion    查询哪些列
     * @param selection    和selectionAgs用于约束查询哪些行
     * @param selectionAgs
     * @param sortOlder    对查询结果进行排序
     * @return Cursor
     */
    @Nullable
    @Override
    public Cursor query(@NonNull Uri uri, @Nullable String[] projetion, @Nullable String selection, @Nullable String[] selectionAgs, @Nullable String sortOlder) {
        switch (uriMatcher.match(uri)) {
            case TABLE1_DIR://查table1 中的所有数据
                break;
            case TABLE1_ITEM://查table1 中的单条数据
                break;
            case TABLE2_DIR://查table2 中的所有数据
                break;
            case TABLE2_ITEM://查table2 中的单条数据
                break;
            default:
                break;
        }
        return null;
    }

    /**
     * @param uri
     * @return 根据传入的内容返回相应的MIME类型
     */
    @Nullable
    @Override
    public String getType(@NonNull Uri uri) {
        switch (uriMatcher.match(uri)) {
            case TABLE1_DIR:
                return "vnd.android.cursor.dir/vnd.com.zsp.runtimepermissiontest.provider.table1";
            case TABLE1_ITEM:
                return "vnd.android.cursor.item/vnd.com.zsp.runtimepermissiontest.provider.table1";
            case TABLE2_DIR:
                return "vnd.android.cursor.dir/vnd.com.zsp.runtimepermissiontest.provider.table2";
            case TABLE2_ITEM:
                return "vnd.android.cursor.item/vnd.com.zsp.runtimepermissiontest.provider.table2";
            default:
                break;
        }
        return null;
    }

    /**
     * @param uri    确定要添加的表
     * @param values 待添加的数据保存在values中
     * @return 返回用于表示这条新纪录的 Uri
     */
    @Nullable
    @Override
    public Uri insert(@NonNull Uri uri, @Nullable ContentValues values) {
        return null;
    }

    /**
     * @param uri           删除哪一张表中的数据
     * @param selection     selectionArgs  约束删除哪些行
     * @param selectionArgs
     * @return 被删除的行数
     */
    @Override
    public int delete(@NonNull Uri uri, @Nullable String selection, @Nullable String[] selectionArgs) {
        return 0;
    }

    /**
     * @param uri           更新哪一张表中的数据
     * @param values        新数据存在values中
     * @param selection     和selectionArgs 用于约束更新哪些行
     * @param selectionArgs
     * @return 受影响的行数
     */
    @Override
    public int update(@NonNull Uri uri, @Nullable ContentValues values, @Nullable String selection, @Nullable String[] selectionArgs) {
        return 0;
    }
}

一个标准的内容URI的写法是

content://com.zsp.runtimepermissiontest.provider/table1

表示期望访问的是com.zsp.runtimepermissiontest这个应用的table1表中的数据

在这个URI后面加一个id

content://com.zsp.runtimepermissiontest.provider/table1/1

表示期望访问的是com.zsp.runtimepermissiontest这个应用的table1表中id位1的数据

以通配符的方式来分别匹配这两种格式的内容URI,规则如下

*: 表示匹配任意长度的字符

#:表示匹配任意长度的数字

所以,一个能够匹配任意表的内容URI格式为:

content://com.zsp.runtimepermissiontest.provider/*

能够匹配table1表中任意一行数据的内容URI格式为

content://com.zsp.runtimepermissiontest.provider/table1/#

借助UriMatcher类可以轻松匹配内容URI。UriMatcher的addURI()方法接收三个参数分别把authority,path,和一个自定义代码传进去。当调用UriMatcher的mach()方法时传入Uri对象,返回一个能够匹配这个Uri对象所定义的自定义代码,利用这个代码可以判断期望访问的是哪张表中的数据了。

MyProvider中的getType()方法,返回一个Uri对象所对应的MIME类型,MIME字符串主要由三部分组成

1、必须以vnd开头

2、如果URI以路径结尾,则后接android.cursor.dir/,如果URI以id结尾,则后接android.cursor.item/

3、最后接上vnd.<authority>.<tath>

content://com.zsp.runtimepermissiontest.provider/table1对应的MIME类型为

vnd.android.cursor.dir/vnd.com.zsp.runtimepermissiontest.provider.table1

content://com.zsp.runtimepermissiontest.provider/table1/1对应的MIME类型为

vnd.android.cursor.item/vnd.com.zsp.runtimepermissiontest.provider.table1

 

                
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值