美文网首页
内容提供器--跨程序共享数据

内容提供器--跨程序共享数据

作者: 小徐andorid | 来源:发表于2018-03-27 08:40 被阅读0次

    内容提供器主要用于在不同应用程序之间进行数据共享。它能提供一套完整的机制,允许一个程序访问另一个程序中的数据,同时还能保证被访问数据的安全 。不同于文件存储和sharedpreference存储这两种全局读写模式,内容提供器可以选择只对某一部分数据(感兴趣的)进行读写,从而保证我们的数据没有被泄露的可能性。

    安卓运行权限分为普通权限和危险权限普通权限指的是那些不会直接威胁到用户数据和隐私安全的权限,对于这部分权限申请系统会自动帮我们授权,而不需要用户手动操作了。普通权限无需做权限处理,只需要在AndroidManifest.xml文件中声明一下即可。危险权限是那些可能会触及用户隐私,或者对设备安全性造成影响的权限,对于这一部分权限的申请,必须用户手动点击授权才可以,否则程序无法实现相应的功能。危险权限很少共9组24个,如果记不住的话那就查表就行。

    1

    为了防止程序崩溃,可以将有关操作放在异常捕获代码块中(try catch块中)如图所示:

    2

    运行权限的核心就是在程序运行过程中由用户授权我们去执行危险操作,程序是不可以擅自做主去执行这些危险操作的。所以第一步是要先判断用户是否已经给过我们权限了。借助的是ContextCompat.checkSelfPermission()方法。这个方法接受两个参数第一个是context第二个参数是具体的权限名。如果用户已经授予我们权利了,直接执行具体的逻辑即可,如果用户没有给我们授权,那么需要调用ActivityCompatrequestPermission()方法来向用户申请授予权限,该方法第一个参数是具体的activity实例,第二个参数是一个String数组,里面存放着要申请的权限名,第三个参数是请求码,只要是唯一值即可,请求码的作用是调用完requestpermission方法之后,系统会弹出一个权限申请得对话框,然后用户可以选择同意或者拒绝我们的权限申请,不管是用户同意还是拒绝,最终都会回调到onRequestPermissionsResult()中,而授权的结果会封装在grantResults参数中,在回调方法中我们依据ActivityCompat.RequestPermissions()方法中请求码的不同而在回调方法中执行不同的申请具体权限的相关逻辑操作(这里的具体权限是指:比如在ActivityCompat.reqiestPermissions方法中我们申请的是打电话的危险权限,其申请码是1,这个申请码随便取,只要唯一即可,那么我们在onRequestPermissionsResult方法中用switch判断不同的申请码,case 1:(这里的1便是上面那个申请码便是我们随便设的1)再加上判断语句判断申请后的授权结果(封装在grantResults数组中参数是否等于相关的参数,进而执行具体的逻辑操作即可。))。具体思路是判断onRequestPermissionsResult()中授权的结果(封装在grantResults数组中)若用户同意怎么样,不同意怎么样。

    3

    访问其他程序中的数据

    内容提供器用法有两种:

    使用内容提供器来读取和操作相应程序中的数据

    创建属于自己的内容提供器给我们的程序数据提供外部访问接口。

    如果一个应用程序通过内容提供器对其数据提供了外部访问接口,那么其他任何应用程序就都可以就这部分数据进行访问。

    对于每一个应用程序来说,如果想要访问内容提供器里的共享数据,一定要借助ContentResolver类,该类实例提供了一系列方法用于对数据的CRUD(包括insert update delete query 有点类似SQLiteDatabase)操作,获得该类实例可以通过Context中的getContentResolver()方法来获取。

    与SQLiteDatabase不同的是,ContentResolver中的CURD方法都是不接受表名参数的而是接收内容URI。内容URI为内容提供器中的数据建立了唯一的标识符,它主要由两部分组成:authority和pathauthority主要用于对不同应用程序进行区分(通常用程序包名的方式来命名),而path则是对同一应用程序中不同的表做区分的,通常加在authority后面。

    内容URI的标准写法比如:content://com.example.app.provider/table1

    内容URI可以清楚的表达出我们想要访问哪个程序中哪张表里的数据,正因如此contentresolver中的增删改查方法才都接收Uri对象作为参数。

    我们需要调用Uri.parse()方法,可以将内容URI解析成Uri对象,然后Uri对象便可以作为参数传递进去了

    然后便可以使用这个Uri对象来查询table表中的数据,Cursor cursor=getContentResolver().query(){uri,projection,selection,selectionArgs,sortOrder};该方法的返回值是一个Cursor对象,我们可以将数据从Cursor对象中逐个读取出来了。读取的思路仍然是通过移动游标位置来遍历Cursor的所有行,然后再取出每一行中相应列的数据。

    添加数据的方法是将待添加的数据组放到ContentValues中,然后调用ContentResolver的insert()方法,将Uri和ContentValues作为参数传入即可。

    4

    更新数据借助ContentResolver的update方法来实现该方法中第一个参数和第二个参数也是Uri对象和ContentValues

    删除数据用ContentResolver的delete()方法

    总结:在update 和insert方法中用到ContentValues,4个方法都会用到Uri对象.只需要获取到应用程序的内容URI然后借助ContentResolver进行CRUD操作即可了。

    创建内容提供器步骤

    实现跨程序共享数据的功能,官方推介的方式是使用内容提供器,可以通过新建一个类去继承ContentProvider的方式来创建一个自己的内容提供器.

    ContentProvider类有6个抽象方法,我们在使用子类继承它的过程中,需要我们将这6个方法全部重写

    其中比较重要的几个方法是onCreat 和getType方法

    5 6 7 8

    实现跨程序数据共享

    9 10 11 12 13

    内容提供器一定要在AndroidManifest.xml文件中注册才可以使用,但是如果使用Android Studio快捷方式创建内容提供器,则注册这一步会被自动完成! 其标志是 在<application>标签内出现了一个新的标签<provider>,我们使用它来对DatabaseProvider这个内容提供器进行注册.android:name 属性指定了DatabaseProvider的类名,android:authorities 属性指定了DatabaseProvider的authority,而enabled和exported属性则是根据我们刚才勾选的状态自动生成的,这里表示允许DatabaseProvider被其他应用程序进行访问.

    然后我们在新建一个新的项目ProviderTest,用这个程序去访问DatabaseTest中的数据

    布局文件略,程序如下(节选一小部分说明问题)

    14 15 16 17 18 19 20

    我们可以这么认为,在你创建好你的内容提供器后,另一个应用程序实际上是通过你新建的内容提供器所提供的内容Uri(可以把它想成是一个接口)来访问不同的应用程序的.比如新建一个ProvideTest项目,通过这个程序去访问DatabaseTest中的数据

    21

    相关文章

      网友评论

          本文标题:内容提供器--跨程序共享数据

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