创建自己的内容提供器

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

创建一个类来继承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标签:



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

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

你可能感兴趣的:(创建自己的内容提供器)