在 Android 7.0 以前 Google 提供的動態申請權限的 API,能夠調用相機拍照,訪問SDcard等操做都只須要申請對應的權限,以下:java
<uses-permission android:name="android.permission.CAMERA" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
可是 7.0 更新以後,Google 收緊了對私有目錄的訪問權限 。Android 7.0 中嘗試傳遞 file://URI 會觸發 FileUriExposedException,由於在 Android 7.0 以後 Google 認爲直接使用本地的根目錄即 file://URI 是不安全的操做,直接訪問會拋出 FileUriExposedExCeption 異常,這就意味着在Android 7.0 之前咱們訪問相機拍照存儲時,若是使用URI的方式直接存儲剪裁圖片就會形成這個異常,那麼如何解決這個問題呢?
Google 爲咱們提供了 FileProvider 類,進行一種特殊的內容提供,FileProvider 是 ContentProvide 的子類,它使用了和內容提供器相似的機制來對數據進行保護,能夠選擇性地將封裝過的 URI 共享給外部,從而提升了應用的安全性。下面就讓咱們看一下如何使用這個內容提供者進行數據訪問的:
1. 使用 FileProvider 獲取 URI 就會將之前的 file://URI 準換成 content://URI,實現一種安全的應用間數據訪問,內容提供者做爲 Android 的四大組件之一,使用一樣須要在清單文件 AndroidManifest.xml 中進行註冊的,註冊方法以下:android
<provider android:name="android.support.v4.content.FileProvider" android:authorities="com.cc.fileprovider" android:exported="false" android:grantUriPermissions="true"> <meta-data android:name="android.support.FILE_PROVIDER_PATHS" android:resource="@xml/file_paths" /> </provider>
2. 在res目錄下建立 xml 文件夾,file_paths.xml 文件內容以下:安全
<?xml version="1.0" encoding="utf-8"?> <paths> <external-path name="camera_rec" path="" /> </paths>
3. 獲取相機權限ide
/** * 自動獲取相機權限 */ private void autoObtainCameraPermission() { if (ContextCompat.checkSelfPermission(this, Manifest.permission.CAMERA) != PackageManager.PERMISSION_GRANTED || ContextCompat.checkSelfPermission(this, Manifest.permission.READ_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) { ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.CAMERA, Manifest.permission.READ_EXTERNAL_STORAGE}, CAMERA_PERMISSIONS_REQUEST_CODE); } else { //有權限直接調用系統相機拍照 } }