创建自己的内容提供器

作者: 大话程序 | 来源:发表于2016-05-19 18:15 被阅读215次

    实现跨程序共享数据的功能,官方推荐的方式就是使用内容提供器

    创建一个类来继承ContentProvider,实现其方法

    • onCreate()方法:初始化内容提供器的时候调用。通常会在这里完成对数据的创建和升级操作,返回true表示内容提供器初始化成功,返回false则表示失败。只有当存在ContentResolver尝试访问我们程序中的数据时,内容提供器才会被初始化
    • query()方法:从内容提供器中查询数据。使用uri参数来确定查询哪张表,查询的结果存放在Cursor对象中返回
    • insert()方法:向内容提供器中添加一条数据,使用uri参数来确定要添加到的表,返回一个用于表示这条新纪录的URI
    • update()方法:更新内容提供器中已有的数据,使用uri参数确定更新哪一张表中的数据,受影响的行数将做为放回值返回
    • delete()方法:从内容提供器中删除数据,使用uri参数来确定删除哪一张表中的数据,被删除的行数将做为返回值返回
    • getType()方法:根据传入的内容URI来返回相应的MIME类型

    数据共享,只是将不涉及用户隐私的数据或可共享的数据提供外部访问接口,用于第三方应用程序来获取,第三方应用程序是通过uri参数来确定资源的,故我们应将我们共享出来的数据在内容提供器中存放

    匹配内容Uri来确定访问的资源

    • 存放Uri:添加内容URI格式,UriMatcher类提供了一个addURI()方法,这个方法接收三个参数,可以分别把权限、路径(可以使用通配符 # )和一个自定义代码传进去
    • 匹配Uri:调用UriMatcher()类的match()方法,一个Uri对象做为参数传入,会和内容提供器中已经添加进来的Uri格式进行匹配,返回值就是某个能够匹配这个Uri对象所对应的自定义代码

    通过返回的自定义代码来执行相应的数据库的CRUD操作

    public class MyProvider extends ContentProvider{
    
      //自定义的代码,用于传入的内容Uri匹配内容提供器中的Uri格式做为返回数据
      public static final int TABLE_DIR = 0;
      
      public static final int TABLE_ITEM = 1;
    
      private static UriMatcher uriMatcher;
    
      static{
        //创建UriMatcher对象
        uriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
        //添加Uri格式
        uriMatcher.addURI("com.example.app.provider", "table", TABLE_DIR);
        uriMatcher.addURI("com.example.app.provider", "table/#", TABLE_ITEM);
      }
    
      @override
      public Curcor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder){
        switch(uriMatcher.match(uri)){  //根据传入的Uri来匹配内容提供器中的URI格式
          case TABLE_DIR:
            //查询table表中的所有数据
            break;
          case TABLE_DIR:
            //查询table表中的单条数据
            break;
          default:
            break;
        }
      }
    ..........
    }
    

    内容提供器是Android四大组件之一
    需要在清单文件中注册,在application标签下创建provider标签:

    <provider
      android:name="<path>"  
      android:authorities="<authority>"  
      android:exported="true" >
    </provider>
    
    • <path>表示:自定义内容提供器的全名
    • <authority>表示:该内容提供器的权限
    • android:exported="true"表示:指定为true,表示该内容提供器可以被其他应用程序访问

    保护隐私数据:
    所有的 CRUD操作都一定要匹配到相应的内容URI格式才能进行,我们不可能向UriMatcher中添加隐私数据的URI,所以这部分数据根本无法被外部程序访问到

    相关文章

      网友评论

        本文标题:创建自己的内容提供器

        本文链接:https://www.haomeiwen.com/subject/pncbrttx.html