权限检查联系人ProfileProvider
每日一贴,今天的内容关键字为权限检查
ProfileProvider继承自AbstractContyactsProvider。
源代码请自行下载
书籍好比一架梯子,它能引领人们登上文化的殿堂;书籍如同一把钥匙,它将帮助我们开启心灵的智慧之窗;书籍犹如一条小船,它会载着我们驶向知识的海洋。
package com.android.providers.contacts; import android.content.ContentValues;
import android.content.Context;
import android.content.res.AssetFileDescriptor;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.net.Uri; import java.io.FileNotFoundException;
import java.util.Locale; /**
* Simple content provider to handle directing profile-specific calls against a separate
* database from the rest of contacts.
*/
public class ProfileProvider extends AbstractContactsProvider { private static final String READ_PERMISSION = "android.permission.READ_PROFILE";
private static final String WRITE_PERMISSION = "android.permission.WRITE_PROFILE"; // The Contacts provider handles most of the logic - this provider is only invoked when the
// URI belongs to a profile action, setting up the proper database.
private final ContactsProvider2 mDelegate; public ProfileProvider(ContactsProvider2 delegate) {
mDelegate = delegate;
} /**
* Performs a permission check on the read profile permission. Checks the delegate contacts
* provider to see whether this is an authorized one-time-use URI.
* @param uri The URI being accessed.
*/
public void enforceReadPermission(Uri uri) {//检查是不是有读权限
if (!mDelegate.isValidPreAuthorizedUri(uri)) {
mDelegate.getContext().enforceCallingOrSelfPermission(READ_PERMISSION, null);
}
} /**
* Performs a permission check on the write profile permission.
*/
public void enforceWritePermission() {//检查是不是有写权限
mDelegate.getContext().enforceCallingOrSelfPermission(WRITE_PERMISSION, null);
}
/**
* 重写getDatabaseHelper,父类的方法
*/
@Override
protected ProfileDatabaseHelper getDatabaseHelper(Context context) {
return ProfileDatabaseHelper.getInstance(context);
} @Override
protected ThreadLocal<ContactsTransaction> getTransactionHolder() {//得到线程当地存储的对象
return mDelegate.getTransactionHolder();
} @Override
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs,
String sortOrder) {
enforceReadPermission(uri);//检查权限,如果没有权限抛出异常
mDelegate.substituteDb(getDatabaseHelper().getReadableDatabase());//替换数据库 profile.db
return mDelegate.queryLocal(uri, projection, selection, selectionArgs, sortOrder, -1);
} @Override
protected Uri insertInTransaction(Uri uri, ContentValues values) {
enforceWritePermission();//检查写权限,如果不存在权限,抛出异常
useProfileDbForTransaction();//启动触发器,并切换数据库到profile.db
return mDelegate.insertInTransaction(uri, values);
} @Override
protected int updateInTransaction(Uri uri, ContentValues values, String selection,
String[] selectionArgs) {
enforceWritePermission();//检查写权限,如果不存在权限,抛出异常
useProfileDbForTransaction();//启动触发器,并切换数据库到profile.db
return mDelegate.updateInTransaction(uri, values, selection, selectionArgs);
} @Override
protected int deleteInTransaction(Uri uri, String selection, String[] selectionArgs) {
enforceWritePermission();//检查写权限,如果不存在权限,抛出异常
useProfileDbForTransaction();//启动触发器,并切换数据库到profile.db
return mDelegate.deleteInTransaction(uri, selection, selectionArgs);
} @Override
public AssetFileDescriptor openAssetFile(Uri uri, String mode) throws FileNotFoundException {
if (mode != null && mode.contains("w")) {
enforceWritePermission();//检查写权限,如果不存在权限,抛出异常
mDelegate.substituteDb(getDatabaseHelper().getWritableDatabase());//切换到profile.db上
} else {
enforceReadPermission(uri);//检查权限,如果不存在权限,抛出异常
mDelegate.substituteDb(getDatabaseHelper().getReadableDatabase());
}
return mDelegate.openAssetFileLocal(uri, mode);
} private void useProfileDbForTransaction() {
ContactsTransaction transaction = getCurrentTransaction();//得到线程当地存储,mTreasactionLocal来自mDelegate对象
SQLiteDatabase db = getDatabaseHelper().getWritableDatabase();//子类重写了getDatabaseHelper()方法 profile.db。
transaction.startTransactionForDb(db, ContactsProvider2.PROFILE_DB_TAG, this);
mDelegate.substituteDb(db);//切换数据库到profile.db
} @Override
protected void notifyChange() {
mDelegate.notifyChange();
} protected void notifyChange(boolean syncToNetwork) {
mDelegate.notifyChange(syncToNetwork);
} protected Locale getLocale() {
return mDelegate.getLocale();
} public void onBegin() {
mDelegate.switchToProfileMode();
mDelegate.onBegin();
} public void onCommit() {
mDelegate.switchToProfileMode();
mDelegate.onCommit();
} @Override
public void onRollback() {
mDelegate.switchToProfileMode();
mDelegate.onRollback();
} @Override
protected boolean yield(ContactsTransaction transaction) {
return mDelegate.yield(transaction);
} @Override
public String getType(Uri uri) {
return mDelegate.getType(uri);
}
}
文章结束给大家分享下程序员的一些笑话语录:
这个世界上只有10种人:懂得二进制的和不懂得二进制的。
---------------------------------
原创文章 By
权限和检查
---------------------------------
权限检查联系人ProfileProvider的更多相关文章
- Android之运行时相机权限和联系人权限获取
原文:Android之运行时相机权限和联系人权限获取 本文链接:http://blog.csdn.net/qq_16628781/article/details/61623502 Android之运行 ...
- Android 开发技巧 - Android 6.0 以上权限大坑和权限检查基类封装
简单介绍 关于运行时权限的说法,早在Google发布android 6.0的时候,大家也听得蛮多的.从用户的角度来讲,用户是受益方,更好的保护用户的意思,而对于开发者来说,无疑增加了工作量. 对于6. ...
- MVC用户登陆验证及权限检查(Form认证)
1.配置Web.conf,使用Form认证方式 <system.web> <authentication mode="None" /> ...
- 实例:ABAP权限对象设计与权限检查的实现(详细)
学习总结,分享给大家,,,(有图有真像) 我在ECC里创建了一张表,随意插入了5条数据 创建权限对象,使分配这个权限的用户只能操作部门编号(edept)为 ‘10’ 的数据. 1. SU20,创建权限 ...
- Mysql 存储过程、函数、触发器和视图的权限检查
当存储过程.函数.触发器和视图创建后,不单单创建者要执行,其它用户也可能需要执行,换句话说,执行者有可能不是创建者本身,那么在执行存储过程时,MySQL是如何做权限检查的? 在默认情况下,MySQL将 ...
- asp.net 使用IHttpModule 做权限检查 登录超时检查(转)
IHttpModule 权限 检查 登录超时检查 这样就不需要每个页面都做一次检查 也不需要继承任何父类. using System;using System.Collections.Generic; ...
- Mysql高级之权限检查原理
原文:Mysql高级之权限检查原理 用户进行数据库操作分为两步: 1 是否有权限连接,根据host,name,password: 2 是否有权限进行CURD: 图示解说: 关于用户权限在哪里进行存放? ...
- aspectj 简单的模拟权限检查、事务、日志记录
package com.ij34.service; public class Hello { public void he() { System.out.println("执行Hello的h ...
- SAP跳过权限检查/前提是有debug权限
SE37,AUTH_CHECK_TCODE加断点: 执行事务代码,进入断点,修改sy-subrc = 0,执行,就可以跳过权限检查. 只给了事务代码权限,没有操作权限: CL_SUID_TOOLS== ...
随机推荐
- squid+nginx+apache
一.前言 二.编译安装 三.安装MySQL.memcache 四.安装Apache.PHP.eAccelerator.php-memcache 五.安装Squid 六.后记 一.前言,准备工作当前,L ...
- 【经典DFS】NYOJ-1058-部分和问题
[题目链接:NYOJ-1058] 看到题目难度是2,所以想也没想,直接循环比较...结果果然... 是错的. #include<cstdio> #include<cstring> ...
- Oracle 课程四之索引
课程目标 完成本课程的学习后,您应该能够: 理解b*tree索引的结构与特征 了解聚簇因子的产生原因 理解分区索引与全局索引的区别及场景 掌握组合索引的高效设计 位图索引的适用场景 全文索引的适用场景 ...
- 【转】ACE开发环境搭建
Windows平台 1) 下载ACE源码 ACE官方网址:http://www.cs.wustl.edu/~schmidt/ACE.html ACE下载地址:http://downloa ...
- 【转】Ofbiz学习经验谈
不可否认,OFBiz这个开源的系统功能是非常强大的,涉及到的东西太多了,其实对我们现在而言,最有用的只有这么几个:实体引擎.服务引擎.WebTools.用户权限管理.最先要提醒各位的是,在配置一个OF ...
- LoadRunner检查点实战
码农博客 即将到期,现将博客中部分文章转载到博客园.转载时略有删减. 一.为什么要使用检查点 为什么要使用检查点,那就要说明一下LR如何判断脚本是否执行成功. LR判断脚本是否执行成功是根据服务器返回 ...
- CSS书写规范、顺序
写了这么久的CSS,但大部分前端er都没有按照良好的CSS书写规范来写CSS代码,这样会影响代码的阅读体验,总结一个CSS书写规范.CSS书写顺序供大家参考,这些是参考了国外一些文章以及我的个人经验总 ...
- javascript AES加密 C#AES解密实现
首先需要引入js类库 crypto-js(开源),地址:http://code.google.com/p/crypto-js 现在很多人无法打开这个地址不要紧,下面我们会将全部代码贴出来 需要引入 a ...
- HDU4553 约会安排
http://www.mamicode.com/info-detail-422707.html 线段树区间覆盖,开两个线段树,一个记录DS,一个NS // #pragma comment(linker ...
- Juicer javascript 模板引擎
模板引擎是为了使用户界面与业务数据(内容)分离而产生的,它可以生成特定格式的文档,用于网站的模板引擎就会生成一个标准的HTML文档. js模板引擎包括如下:template官方参考:http://au ...