安卓7.0解决部分勒索软件问题 安卓7.0包含正义代码

来源:本网整理

1、首先我们需要在AndroidManifest中的application下添加provider:xml version="1.0"encoding="utf-8?com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" package="com.ijuyin.prints.news">com.ijuyin.prints.news.provider" android:exported="false" android:granturipermissions="true">provider>在这里我们需要注意一下其中设置的各种属性的含义:authorities:是该项目的包名+providergrantUriPermissions:必须是true,表示授予 URI 临时访问权限 exported:必须是false resource:中的@xml/file_paths是我们接下来要在资源文件目录下添加的文件2、在res目录下新建一个xml文件夹,并且新建一个file_paths的xml文件(如下图)设置file_path路径.png3、打开file_paths.xml文件添加如下内容xml version="1.0"encoding="utf-8?com.ijuyin.prints.news/">external-path></external-path></paths>需要注意的是:path:需要临时授权访问的路径(.代表在相机调用时候访问的是所有路径,而文件写入时访问的路径是Android/data/com.ijuyin.prints.news/)name:是你为设置的这个访问路径起的名字4、接下来便是修改适配Android 7.0及以上系统的代码第一部分是对于相机模块的修改Open cameraprivate void showCameraAction(){if(ContextCompat.checkSelfPermission(getContext(),Manifest.permissionWRITE_EXTERNAL_STORAGE)!PackageManager.PERMISSION_GRANTED){requestPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE,getString(R.string.mis_permission_rationale_write_storage),REQUEST_STORAGE_WRITE_ACCESS_PERMISSION);} else {Intent intent=new Intent(MediaStore.ACTION_IMAGE_CAPTURE);if(intent.resolveActivity(getActivity().getPackageManager())!null){try {mTmpFile=FileUtils.createTmpFile(getActivity());} catch(IOException e){e.printStackTrace();}Uri imageUri;if(mTmpFile!null&mTmpFile.exists()){if(Build.VERSION.SDK_INT>=Build.VERSION_CODES.M){String authority=getActivity().getPackageName()+".provider;imageUri=FileProvider.getUriForFile(getActivity(),authority,mTmpFile);} else {imageUri=Uri.fromFile(mTmpFile);}intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);intent.putExtra(MediaStore.EXTRA_OUTPUT,imageUri);startActivityForResult(intent,REQUEST_CAMERA);} else {Toast.makeText(getActivity(),R.string.mis_error_image_not_exist,ToastLENGTH_SHORT).show();}} else {Toast.makeText(getActivity(),R.string.mis_msg_no_camera,Toast.LENGTH_SHORT)show();}}}第二部分是对文件写入模块的代码修改private static Handler mHandler=new Handler(){Overridepublic void handleMessage(Message msg){if(msg.what=DOWN_UPDATE){mProgress.setProgress(progress);} else if(msg.what=DOWN_OVER){if(null!downloadDialog&downloadDialog.isShowing()){try {downloadDialog.dismiss();} catch(Exception e){e.printStackTrace();}}File apkfile=new File(apkPath);if!apkfile.exists()){return;}Intent intent=new Intent(Intent.ACTION_VIEW);if(Build.VERSION.SDK_INT>=Build.VERSION_CODES.N){intent.setFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);String authority=mContext.getPackageName()+".provider;Uri contentUri=FileProvider.getUriForFile(mContext,authority,apkfile);intent.setDataAndType(contentUri,"application/vnd.android.package-archive");} else {intent.setDataAndType(Uri.fromFile(apkfile),"application/vnd.android"+.package-archive");intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);}mContext.startActivity(intent);}}};其中最核心的部分是配置provider.png需要注意的地方是:首先我们对Android系统的型号做出判断添加flags,表明我们要被授予什么样的临时权限 以前我们直接 Uri.fromFile(apkFile)构建出一个Uri,现在我们使用FileProvider.getUriForFile(getActivity(),getActivity().getPackageName()+".provider",mTmpFile);其中getActivity().getPackageName()指的是该项目的应用包名(此处调用的是在fragment,所以使用的是getActivity())通过以上4步的设置操作,就可以完全解决Android 7.0及以上权限问题导致的崩溃问题。望采纳,谢谢www.zgxue.com防采集请勿采集本网。

s">

安卓7.0解决部分勒索软件问题 安卓7.0包含正义代码

作者:佚名 字体:[增加 减小] 来源:IT之家 时间:07-11 08:44:44 我要评论 有一天打开电脑,发现电脑已经被锁住,窗口弹出说明:如果你不给钱,就把你的电脑清空,这就是遇到了勒索软件。近年来,这种勒索已经频频出现在安卓手机上,手机里的重要资料可能比电脑里还多,这时候怎么办,真的不得不给它钱?安卓7.0的发布,带来了正义的守护 ">

有一天打开电脑,发现电脑已经被锁住,窗口弹出说明:如果你不给钱,就把你的电脑清空,这就是遇到了勒索软件。近年来,这种勒索已经频频出现在安卓手机上,手机里的重要资料可能比电脑里还多,这时候怎么办,真的不得不给它钱?安卓7.0的发布,带来了正义的守护。

将 targetSdkVersion 设置到23(不包含)以下。API23对应Android6.0,涉及到动态运行时权限,无权限就会崩溃。

勒索软件是近年来冒出的比较让人头疼的恶意软件之一,其基本做法是锁住用户的文件或是整个设备,然后再向用户勒索钱财,否则就不会给用户解锁,大多数情况下他们往往能够得逞,毕竟如今手机对于人们的重要性非同一般。

也不是所有。大部分软件是可以限制权限的,不会造成系统崩溃之类的问题,不过没什么必要最好不要限制,有可能会使你所限制的软件打不开,或者是使用过程中接不了电话什么的。欢迎追问

安卓7.0解决部分勒索软件问题 安卓7.0包含正义代码

近日安全公司Symantec发现,Android7.0Nougat在一定程度上能够防范勒索软件的攻击。他们发现,安卓7.0对resetPasswordAPI做了一定的修改,至少能够使部分勒索软件失效。具体而言,这个修改后的API只能用来设置初始密码,而不能用来重置密码,意味着第三方应用是无法重置锁屏密码的。

动态设置权限或者 build.gradle里面的targetSdkVersion设置为22,这样可以简单粗暴的解决奔溃

安卓7.0解决部分勒索软件问题 安卓7.0包含正义代码

但这也意味着那些从来不设密码的用户仍然会处在危险之中,因为勒索软件仍然可以用该API来设置一个初始密码。另外,一些ROOT后的设备也仍然会处在危险之中。

你好,极少数的手机在刷root的时候会把系统刷崩溃了,还有那个维修人员肯定坑你可以去各大安卓论坛里找找看有没有你的手机型号论坛然后找找刷机教程(或者救砖教程),然后就可以解决了。希望能帮助到你!

话说自从google出来Android 7.0系统之后,我们公司的测试小伙伴就向我提出了7.0的bug,接下来就着手查阅了下问题是出在哪里的,该如何来解决呢。bug日志是长这样子的:android.os.FileUriExposedException:file:/storage/emulated/0/ys_toutiao.apk exposed beyond app through Intent.getData()at android.os.StrictMode.onFileUriExposed(StrictMode.java:1816)at android.net.Uri.checkFileUriExposed(Uri.java:2350)at android.content.Intent.prepareToLeaveProcess(Intent.java:9076)at android.content.Intent.prepareToLeaveProcess(Intent.java:9037)at android.app.Instrumentation.execStartActivity(Instrumentation.java:1530)at android.app.Activity.startActivityForResult(Activity.java:4391)at android.support.v4.app.BaseFragmentActivityJB.startActivityForResult(BaseFragmentActivityJB.java)at android.support.v4.app.FragmentActivity.startActivityForResult(FragmentActivity.java)at android.app.Activity.startActivityForResult(Activity.java:4335)at android.support.v4.app.FragmentActivity.startActivityForResult(FragmentActivity.java)at android.app.Activity.startActivity(Activity.java:4697)at android.app.Activity.startActivity(Activity.java:4665)atcom.ijuyin.prints.news.utils.VersionUtils$1.handleMessage(VersionUtils.java)at android.os.Handler.dispatchMessage(Handler.java:105)at android.os.Looper.loop(Looper.java:156)at android.app.ActivityThread.main(ActivityThread.java:6524)at java.lang.reflect.Method.invoke(Method.java)atcom.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:941)atcom.android.internal.os.ZygoteInit.main(ZygoteInit.java:831)也就是说是在什么情况下会出现呢看1、是在调用系统相机的时候;2、是在写入文件的时候,在我这里是强制升级后下载完成安装Apk时;关于FileUriExposedException 异常的描述是这样子的:针对于权限部分,Android7.0是google推出的对权限做了一个更新即不允许出现以file:/的形式调用隐式APP系统,也就是说以前呢,Uri的获取方式是以file:/xxx的样式来,那么我们也就是通过Uri.fromFile()来获取如今放在7.0及以上系统呢,这样子就不行啦;如今的解决关键在哪里呢,需要在应用间共享文件,也就是需要发送一项content:/URI,并授予 URI 临时访问权限。进行此授权的最简单方式是使用FileProvider类。嗯的,FileProvider1、首先我们需要在AndroidManifest中的application下添加provider:xml version="1.0"encoding="utf-8?xmlns:tools="package="com.ijuyin.prints.news">android:name="com.ijuyin.prints.news.base.BaseApplication"android:allowBackup="trueandroid:hardwareAccelerated="trueandroid:icon="@mipmap/ic_launcherandroid:label="@string/text_app_nameandroid:supportsRtl="trueandroid:theme="@style/AppThemetools:replace="android:labelandroid:fullBackupContent="false">android:name="android.support.v4.content.FileProviderandroid:authorities="com.ijuyin.prints.news.provider"android:exported="falseandroid:grantUriPermissions="true">android:name="android.support.FILE_PROVIDER_PATHSandroid:resource="@xml/file_paths"/>在这里我们需要注意一下其中设置的各种属性的含义:authorities:是该项目的包名+providergrantUriPermissions:必须是true,表示授予 URI 临时访问权限exported:必须是falseresource:中的@xml/file_paths是我们接下来要在资源文件目录下添加的文件2、在res目录下新建一个xml文件夹,并且新建一个file_paths的xml文件设置file_path路径.png3、打开file_paths.xml文件添加如下内容xml version="1.0"encoding="utf-8?name="camera_photospath="."/>name="files_rootpath="Android/data/com.ijuyin.prints.news/"/>name="external_storage_rootpath="."/>需要注意的是:path:需要临时授权访问的路径(.代表在相机调用时候访问的是所有路径,而文件写入时访问的路径是Android/data/com.ijuyin.prints.news/)name:是你为设置的这个访问路径起的名字4、接下来便是修改适配Android 7.0及以上系统的代码第一部分是对于相机模块的修改Open cameraprivate void showCameraAction(){if(ContextCompat.checkSelfPermission(getContext(),Manifest.permissionWRITE_EXTERNAL_STORAGE)!PackageManager.PERMISSION_GRANTED){requestPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE,getString(R.string.mis_permission_rationale_write_storage),REQUEST_STORAGE_WRITE_ACCESS_PERMISSION);} else {Intent intent=new Intent(MediaStore.ACTION_IMAGE_CAPTURE);if(intent.resolveActivity(getActivity().getPackageManager())!null){try {mTmpFile=FileUtils.createTmpFile(getActivity());} catch(IOException e){e.printStackTrace();}Uri imageUri;if(mTmpFile!null&mTmpFile.exists()){if(Build.VERSION.SDK_INT>=Build.VERSION_CODES.M){String authority=getActivity().getPackageName()+".provider;imageUri=FileProvider.getUriForFile(getActivity(),authority,mTmpFile);} else {imageUri=Uri.fromFile(mTmpFile);}intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);intent.putExtra(MediaStore.EXTRA_OUTPUT,imageUri);startActivityForResult(intent,REQUEST_CAMERA);} else {Toast.makeText(getActivity(),R.string.mis_error_image_not_exist,ToastLENGTH_SHORT).show();}} else {Toast.makeText(getActivity(),R.string.mis_msg_no_camera,Toast.LENGTH_SHORT)show();}}}第二部分是对文件写入模块的代码修改private static Handler mHandler=new Handler(){Overridepublic void handleMessage(Message msg){if(msg.what=DOWN_UPDATE){mProgress.setProgress(progress);} else if(msg.what=DOWN_OVER){if(null!downloadDialog&downloadDialog.isShowing()){try {downloadDialog.dismiss();} catch(Exception e){e.printStackTrace();}}File apkfile=new File(apkPath);if!apkfile.exists()){return;}Intent intent=new Intent(Intent.ACTION_VIEW);if(Build.VERSION.SDK_INT>=Build.VERSION_CODES.N){intent.setFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);String authority=mContext.getPackageName()+".provider;Uri contentUri=FileProvider.getUriForFile(mContext,authority,apkfile);intent.setDataAndType(contentUri,"application/vnd.android.package-archive");} else {intent.setDataAndType(Uri.fromFile(apkfile),"application/vnd.android"+.package-archive");intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);}mContext.startActivity(intent);}}};其中最核心的部分是配置provider.png需要注意的地方是:首先我们对Android系统的型号做出判断添加flags,表明我们要被授予什么样的临时权限以前我们直接 Uri.fromFile(apkFile)构建出一个Uri,现在我们使用FileProvider.getUriForFile(getActivity(),getActivity().getPackageName()+".provider",mTmpFile);其中getActivity().getPackageName()指的是该项目的应用包名(此处调用的是在fragment,所以使用的是getActivity())通过以上4步的设置操作,就可以完全解决android 7.0及以上权限问题导致的崩溃问题内容来自www.zgxue.com请勿采集。

免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
Copyright © 2017 www.zgxue.com All Rights Reserved