存储卡内容不可见的DDMS文件浏览器Android 6.0



Android 6.0改变了其管理卡挂载的方式,这使得显示不正确。

直到5。我们可以通过层次结构

下的DDMS透视图(Eclipse)访问SDCard内容。

/mnt/shell/…

下的文档

/sdcard/

我在DDMS下看不到这个目录的任何内容,但在PC或其他应用程序(如Astro)中看不到。

为了能够看到该内容,我应该在Eclipse(DDMS)中设置什么?

从Android 6.0开始,第三方应用无法看到sd卡的内容。

在Android 6.0中,第三方应用不能访问sdcard_r和sdcard_rw gid。控件来控制访问合适的运行时视图。跨用户使用everyone GID阻止交互。

https://source.android.com/devices/storage/

作为附加信息,Android 6.0引入了可接受存储运行时权限,它们对与设备存储的交互施加了限制。

希望对你有帮助。

关于如何从DDMS到Android 6.0访问文件。此操作是不允许的。如果你需要从你的应用程序访问文件,你可以使用这个源代码示例:

   @Override
   protected void onCreate(Bundle savedInstanceState) {
        mPermissions = new String[] { Manifest.permission.WRITE_EXTERNAL_STORAGE };
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
           boolean isAllow = ContextCompat.checkSelfPermission(this, mPermissions[0]) == PackageManager.PERMISSION_GRANTED;
           if (!isAllow) {
              if (shouldShowRequestPermissionRationale(mPermissions[0])) {
                 // There is you need to display confirmation dialog about why you need to get this permission. 
                 if (confirm("You need to copy database to  device's storage") == YES) {
                     requestPermissions(mPermissions, REQUEST_CODE_ASK_PERMISSIONS)   
                  } else {
                     // User does not agree with your requirements
                     // You should decide how the app will work in this case.
                     message("You can't use this app!");
                     finish();
                  }
                  return;
              }
              requestPermissions(mPermissions, REQUEST_CODE_ASK_PERMISSIONS);
           }
        } else {
          runTheApp();
        }
   }
 @Override
 public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
            switch (requestCode) {
                case REQUEST_CODE_ASK_PERMISSIONS:
                    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
                        if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                            runTheApp();
                        } else {
                            message("You can't use this app!")
                        }
                    }
                break;
                case REJECT_CODE_PERMISSIONS:
                    break;
                default:
                    super.onRequestPermissionsResult(requestCode, permissions, grantResults);
            }
    }