[研究ノート] Anroidランタイム権限と基本的な使用のコンテンツプロバイダー

免責事項:この記事はブロガーオリジナル記事です、続くBY-SAのCC 4.0を著作権契約、複製、元のソースのリンクと、この文を添付してください。
このリンク: https://blog.csdn.net/A1344714150/article/details/100160627

ランタイム権限

Android6.0バージョンを導入した後、ユーザーが選択あなたはまだアプリケーションの他の機能を使用することができ、この権限を拒否した場合でも、アプリケーションを承認することができます。

すべてのAndroid危険な許可、9群24件の権限の合計:

Dangerous Permissions:
  group:android.permission-group.CONTACTS
          permission:android.permission.WRITE_CONTACTS
          permission:android.permission.GET_ACCOUNTS
          permission:android.permission.READ_CONTACTS

   group:android.permission-group.PHONE
          permission:android.permission.READ_CALL_LOG
          permission:android.permission.READ_PHONE_STATE
          permission:android.permission.CALL_PHONE
          permission:android.permission.WRITE_CALL_LOG
          permission:android.permission.USE_SIP
          permission:android.permission.PROCESS_OUTGOING_CALLS
          permission:com.android.voicemail.permission.ADD_VOICEMAIL

    group:android.permission-group.CALENDAR
          permission:android.permission.READ_CALENDAR
          permission:android.permission.WRITE_CALENDAR

    group:android.permission-group.CAMERA
          permission:android.permission.CAMERA

    group:android.permission-group.SENSORS
          permission:android.permission.BODY_SENSORS

    group:android.permission-group.LOCATION
          permission:android.permission.ACCESS_FINE_LOCATION
          permission:android.permission.ACCESS_COARSE_LOCATION

    group:android.permission-group.STORAGE
          permission:android.permission.READ_EXTERNAL_STORAGE
          permission:android.permission.WRITE_EXTERNAL_STORAGE

    group:android.permission-group.MICROPHONE
          permission:android.permission.RECORD_AUDIO

    group:android.permission-group.SMS
          permission:android.permission.READ_SMS
          permission:android.permission.RECEIVE_WAP_PUSH
          permission:android.permission.RECEIVE_MMS
          permission:android.permission.RECEIVE_SMS
          permission:android.permission.SEND_SMS
          permission:android.permission.READ_CELL_BROADCASTS

注:ユーザーの承認権限たら、許可グループを対応する権限を持つ他のすべても、許可されます。

プログラムを実行する許可を申請します

次のように最初のAndroidManifest.xmlファイルを変更します。

<manifest> 
<uses-permission android name="android.permission.CALL_PHONE"/> 
</manifest>

コアコードを実行する許可を適用します。

onClick(){ 
//如果用户未授权拨打电话权限,申请运行时权限 if(ContextCompat.checkSelfPermission(MainActivity.this,Manifest. permission.CALL_PHONE)!=PackageManager.PERMISSION_GRANTED){ 
//参数1:Activity的实例;参数2:String数组,放置需要申请的权限名 
//参数3:请求码,只要是唯一值就可以了 
ActivityCompat.requestPermissions(MainActivity.this,new String[] {
Manifest.permission.CALL_PHONE},1); 
}else{ 
call(); 
} 
} 

call(){ 
try{ 
Intent intent = new Intent(Intent.ACTION_CALL); 
intent.setData(Uri.parse("tel:10086")); 
startActivity(intent); 
}catch(Exception e){ 
... 
} 
}
//调用完requestPermission()方法后,无论用户是否授权,最终都会回调到此方法中 
public void onRequestPermissionsResult(int requestCode,String[] permissions, int[] grantResults){
switch(requestCode){ 
case 1: if(grantResults.length>0 && grantResults[0]==PackageManager. PERMISSION_GRANTED){
 call(); 
}else{ 
Toast.makeText(this,"you denied the permission",Toast. LENGTH_SHORT).show(); 
} break; 
default:
 } 
}

 

コンテンツプロバイダ

他のプログラムからデータにアクセスするには

あなたは、コンテンツプロバイダは、データを共有にアクセスしたい場合、我々は、ContentResolverのクラスに依存しなければなりません。

ContentResolverのクラスは、メソッド及びクラス一連の同様のデータCRUD操作をSQLiteDatabase提供します。

ContentResolverのクラスはテーブル名パラメータを受け入れますが、パラメータウリを受信しません。

コンテンツURIのパスと二液型組成権限、権限を挙げることが一般的パッケージ名の方法により、異なるアプリケーションを区別するために使用され、パスは、異なるテーブル間の区別をするために使用されるのと同じ手順です、通常、権限に追加。

如:内容://com.example.app.provider/table1

URI文字列の内容を取得した後、それはまた、パラメータとしてURIオブジェクトに解決する必要があります。

Uri uri = Uri.parse("content://com.example.app.provider/table1");

テーブルを使用してウリTABLE1のクエリデータ:

//参数1:指定查询某个应用程序下的某一张表;参数2:指定查询的列名; 
//参数3:指定where的约束条件;参数4:为where中的占位符提供具体的值 
//参数5:指定查询结果的排序方式 
Cursor cursor = getContentResolver().query( uri, projection, selection, selectionArgs, sortOrder ); 
if(cursor!=null){ 
while(cursor.moveToNext()){ 
String column1 = cursor.getString(cursor.getColumnIndex("column1"));
int column2 = cursor.getInt(cursor.getColumnIndex("column2"));
} 
cursor.close(); 
}

データコアのコードを追加します。

ContentValues values = new ContentValues(); 
values.put("column1","text"); 
values.put("column2",1); 
getContentResolver().insert(uri,values);

データコアコードを変更します。

ContentValues values = new ContentValues(); 
values.put("column1",""); 
getContentResolver().update(uri,values,"column1 = ? and column2 = ?", 
new string[]{"text","1"});

データコアコードを削除します。

getContentResolver().delete(uri,"column2 = ?",new String[]{"1"});

システムは、連絡先情報を読み取ります。

コアコードに実装ステップ1:

onCreate(){ 
ListView contactsView = (ListView)findViewById(...); 
adapter = new ArrayAdapter(...); 
contactsView.setAdapter(adapter); 
//如果未授权读取联系人权限,申请授权 if(ContextCompat.checkSelfPermission(this,Manifest.permission.READ_ CONTACTS)!=PackageManager.PERMISSION_GRANTED){ 
ActivityCompat.requestPermissions(this,new String[]{Manifest.per mission.READ_CONTACTS},1); }else{ 
readContacts(); 
} 
} 

readContacts(){ 
Cursor cursor = null; 
try{ 
//查询联系人数据 
cursor = getContentResolver().query(ContactsContract.CommonDataKinds. Phone.CONTENT_URI,null,null,null.null); 
if(cursor!=null){ 
while(cursor.moveToNext()){ 
//获取联系人姓名 
String displayName = cursor.getString(cursor.getColumnIndex (ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME)); 
//获取联系人手机号 
String number = cursor.getString(cursor.getColumnIndex (ContactsContract.CommonDataKinds.Phone.NUMBER)); contactsList.add(displayName+"\n"+number); 
} 
adapter.notifyDataSetChanged(); 
} 
}catch(Exception e){
 ... 
}finally{ 
if(cursor!=null){ 
cursor.close(); 
} 
} 
} 

public void onRequestPermissionsResult(int requestCode,String[] permissions, int[] grantResults){ 
switch(requestCode){ 
case 1: if(grantResults.length>0 && grantResults[0]==PackageManager. PERMISSION_GRANTED){ readContacts(); }else{ 
Toast.makeText(this,"you denied the permission",Toast. LENGTH_SHORT).show(); 
} break; 
default: 
} 
}

ステップ2連絡先のシステム構成は、許可をお読みください。

<manifest> <uses-permission android:name="android.permission.READ_CONTACTS"/> </manifest>

独自のコンテンツプロバイダを作成します。

カスタムコンテンツプロバイダのコアコード:

class MyProvider extends ContentProvider{ 
//初始化内容提供器时调用,一般在这完成数据库的创建和升级操作 
boolean onCreate(){ 
return false; 
} 
//从内容提供器中查询数据 
Cursor query(Uri uri,String[] projection,String selection,String[] selectionArgs,String sortOrder){ 
return null; 
} 
//向内容提供器中添加数据,添加完成后,返回一个用于表示这条新记录的URI 
Uri insert(Uri uri,ContentValues values){ 
return null; 
} 
//更新内容提供器中已有的数据,返回受影响的行数 
int update(Uri uri,ContentValues values,String selection,String[] selectionArgs){ 
return 0; 
} 
//从内容提供器中删除数据,返回受影响的行数 
int delete(Uri uri,String selection,String[] selectionArgs){ 
return 0; 
} 
//根据传入的内容URI来返回相应的MIME类型 
String getType(Uri uri){ 
return null; 
} 
}

UriMatcherを使用して、このクラスは簡単にURIの内容を照合することができます

達成するためのコアコード:

class MyProvider extends ContentProvider{ 
public static final int TABLE1_DIR = 0; 
public static final int TABLE1_ITEM = 1; 
public static final int TABLE1_DIR = 2; 
public static final int TABLE1_ITEM = 3; 
private static UriMatcher uriMatcher; 

static{ uriMatcher = new UriMatcher(UriMatcher.NO_MATCH); 
//参数1:authority;参数2:path;参数3:自定义代码 uriMatcher.addURI("com.example.app.provider","table1",TABLE1_DIR); uriMatcher.addURI("com.example.app.provider","table1/#",TABLE1_ITEM); uriMatcher.addURI("com.example.app.provider","table2",TABLE2_DIR); uriMatcher.addURI("com.example.app.provider","table2/#",TABLE2_ITEM); 
} 

Cursor query(Uri uri,String[] projection,String selection,String[] selectionArgs,String sortOrder){ 
//调用UriMatcher的match()方法时,返回值是某个能够匹配这个Uri对象 
//所对应的自定义代码 
switch(uriMatcher.match(uri){ 
case TABLE1_DIR: 
//查询table1表中的所有数据 
break; 
case TABLE1_ITEM: 
//查询table1表中的单条数据 
break; 
case TABLE2_DIR: 
//查询table2表中的所有数据 
break; 
case TABLE2_ITEM: 
//查询table2表中的单条数据 
break; 
default: 
break; 
}
}
}

getType()メソッドは、すべてのURIオブジェクトは、対応するMIMEタイプを取得するために提供されなければならないコンテンツプロバイダです。

3つの部分から構成さURI文字列に対応するMIMEコンテンツ:

1 VNDで始まる必要があります

2コンテンツURIがIDで終わる場合android.cursir.dirの/に続くコンテンツURIのパスの端部は、次いでandroid.cursir.itemに従った場合/

3最後に接続VND。<権威>。<パス>

パーフェクトMyProviderコード:

String getType(Uri uri){ 
switch(uriMatcher.match(uri){ 
case TABLE1_DIR: return "vnd.android.cursor.dir/vnd.com.example.app.provider.table1"; 
case TABLE1_ITEM: return "vnd.android.cursor.item/vnd.com.example.app.provider.table1"; case TABLE2_DIR: return "vnd.android.cursor.dir/vnd.com.example.app.provider.table2"; 
case TABLE2_ITEM: return "vnd.android.cursor.item/vnd.com.example.app.provider.table2"; 
default: 
    break; 
} 
return null;
}

 

おすすめ

転載: blog.csdn.net/A1344714150/article/details/100160627