zoukankan      html  css  js  c++  java
  • Android使用ContentProvide(内容提供者)向其他应用程序共享数据

    使用ContentProvide(内容提供者)向其他应用程序共享数据

    ContentProvider android中的作用是对外共享数据,也就是说你可以通过ContentProvider把应用中的数据共享给其他应用访问,其他应用可以通过ContentProvider 对你应用中的数据进行添删改查。关于数据共享,以前我们学习过文件操作模式,知道通过指定文件的操作模式为Context.MODE_WORLD_READABLE Context.MODE_WORLD_WRITEABLE同样也可以对外共享数据。那么,这里为何要使用ContentProvider 对外共享数据呢?是这样的,如果采用文件操作模式对外共享数据,数据的访问方式会因数据存储的方式而不同,导致数据的访问方式无法统一,如:采用xml文件对外共享数据,需要进行xml解析才能读取数据;采用sharedpreferences共享数据,需要使用sharedpreferences API读取数据。

    使用ContentProvider对外共享数据的好处是统一了数据的访问方式。

    当应用需要通过ContentProvider对外共享数据时,

    第一步需要继承ContentProvider并重写下面方法:

    public class PersonContentProvider extends ContentProvider{

       public boolean onCreate(){} //内容提供者第一次被创建的时候调用的方法

       public Uri insert(Uri uri, ContentValues values)

       public int delete(Uri uri, String selection, String[] selectionArgs)

       public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs)

       public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder)

       public String getType(Uri uri)}

    第二步需要在AndroidManifest.xml使用<provider>对该ContentProvider进行配置,为了能让其他应用找到该ContentProvider  ContentProvider 采用了authorities(主机名/域名)对它进行唯一标识,你可以把ContentProvider看作是一个网站(想想,网站也是提供数据者),authorities 就是他的域名:

    <manifest .... >

        <application android:icon="@drawable/icon" android:label="@string/app_name">

            <provider android:name=".PersonContentProvider" android:authorities="cn.itcast.providers.personprovider"/>

        </application>

    </manifest>

     

    第三步定义一个路径匹配器

    //创建了一个路径的识别器uriMatcher 默认的返回时,如果没有找到匹配的类型 返回-1

    Public static final UriMatcher matcher = new UriMatcher(UriMatcher.NO_MATCH);

    //UriMatcher.NO_MATCH-1

     

    第四步向路径匹配器中指定路径的匹配规则

    Public static final int ALL_PERSONS=1;

    static{

    matcher.addURI(authority,path,code);

    matcher.addURI(“cn.itcast.db.personprovider”,”person”,ALL_PERSONS);

    //指定一个路径的匹配规则,可设置多个

    //如果路径满足content://cn.itcast.db.provider/persons 返回值就是(ALL_PERSONS 1

    参数说明:

    authority:主机名

    path:定义路径路径,实现方法

    code:ALL_PERSONS//为其绑定一个返回值

    }

    自定义的含义

    content://cn.itcast.db.provider/persons

    //代表获取数据库person表中的所有的内容

    content://cn.itcast.db.provider/person/10

    content://cn.itcast.db.provider/person/# 匹配数据

    //代表获取数据库person表中第十个元素

     

    第五步设置匹配码对应的方法---(一般与数据库联动操作)

    在对应的CRUD方法中加入

    int result = matcher.match(uri)

    switch(result)

    case ALL_PERSONS:

    //符合content://cn.itcast.db.provider/persons 代表的返回所有的数据

           personDBDao dao = new PersonDBDao(getContext());

           return dao.findAllbyCursor();

    break;

    case PERSON:

    //content://cn.itcast.db.provider/person/10

    long id = ContentUris.parseId(uri);

    break;

    -----------------------------------------------------------------------------------------

     

    使用ContentProvider共享数据

    ContentProvider类主要方法的作用:

    public boolean onCreate()

    该方法在ContentProvider创建后就会被调用, Android开机后, ContentProvider在其它应用第一次访问它时才会被创建。

    public Uri insert(Uri uri, ContentValues values)

    该方法用于供外部应用往ContentProvider添加数据。

    public int delete(Uri uri, String selection, String[] selectionArgs)

    该方法用于供外部应用从ContentProvider删除数据。

    public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs)

    该方法用于供外部应用更新ContentProvider中的数据。

    public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder)

    该方法用于供外部应用从ContentProvider中获取数据。

    public String getType(Uri uri)

    该方法用于返回当前Url所代表数据的MIME类型。如果操作的数据属于集合类型,那么MIME类型字符串应该以vnd.android.cursor.dir/开头,例如:要得到所有person记录的Uricontent://cn.itcast.provider.personprovider/person,那么返回的MIME类型字符串应该为:“vnd.android.cursor.dir/person”。如果要操作的数据属于非集合类型数据,那么MIME类型字符串应该以vnd.android.cursor.item/开头,例如:得到id10person记录,Uricontent://cn.itcast.provider.personprovider/person/10,那么返回的MIME类型字符串应该为:“vnd.android.cursor.item/person”

     ------------------------------------------------------------------------------------------------------------------

    ContentUris类使用介绍

    ContentUris类用于获取Uri路径后面的ID部分,它有两个比较实用的方法:

    withAppendedId(uri, id)用于为路径加上ID部分:

    Uri uri = Uri.parse("content://cn.itcast.provider.personprovider/person")

    Uri resultUri = ContentUris.withAppendedId(uri, 10);

    //生成后的Uri为:content://cn.itcast.provider.personprovider/person/10

     

    parseId(uri)方法用于从路径中获取ID部分:

    Uri uri = Uri.parse("content://cn.itcast.provider.personprovider/person/10")

    long personid = ContentUris.parseId(uri);//获取的结果为:10

     

      ------------------------------------------------------------------------------------------------------------------

    Uri介绍

    Uri代表了要操作的数据,Uri主要包含了两部分信息:1》需要操作的ContentProvider 2》对ContentProvider中的什么数据进行操作,一个Uri由以下几部分组成:

    Android-使用ContentProvide(内容提供者)向其他应用程序共享数据 - 我行偶素 - 笔记

     

     

    ContentProvider(内容提供者)的scheme已经由Android所规定, scheme为:content://

    主机名(或叫Authority)用于唯一标识这个ContentProvider,外部调用者可以根据这个标识来找到它。

    路径(path)可以用来表示我们要操作的数据,路径的构建应根据业务而定,如下:

    要操作person表中id10的记录,可以构建这样的路径:/person/10

    要操作person表中id10的记录的name字段, person/10/name

    要操作person表中的所有记录,可以构建这样的路径:/person

    要操作xxx表中的记录,可以构建这样的路径:/xxx

    当然要操作的数据不一定来自数据库,也可以是文件、xml或网络等其他存储方式,如下:

    要操作xml文件中person节点下的name节点,可以构建这样的路径:/person/name

    如果要把一个字符串转换成Uri,可以使用Uri类中的parse()方法,如下:

    Uri uri = Uri.parse("content://cn.itcast.provider.personprovider/person")

     

  • 相关阅读:
    Docker系列
    Eclipse 安装TestNG插件,结合Maven使用
    HttpClient设置忽略SSL,实现HTTPS访问, 解决Certificates does not conform to algorithm constraints
    Jenkins Html Rport 使用frame报错解决办法
    Zend Framework1 框架入门(针对Windows,包含安装配置与数据库增删改查)
    Windows下Nginx配置SSL实现Https访问(包含证书生成)
    Windows下Nginx Virtual Host多站点配置详解
    幽灵般的存在:零宽空白
    我的公司培训讲义(2):设计模式思想精要教程
    突如其来而又必然的离职
  • 原文地址:https://www.cnblogs.com/622698abc/p/2741310.html
Copyright © 2011-2022 走看看