本文主要是介绍android 杀毒 源代码,android杀毒软件功能和代码分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
程序从onCreate函数开始运行
然后在onCreate中
使用activity_main.xml和baseadapterlist.xml的界面部署文件
setContentView(R.layout.activity_main);
setContentView(R.layout.baseadapterlist);
mListView变量是一种ListView类型的布局
mListView = (ListView)
findViewById(R.id.baselist);
设置mListView里面的Adapter,也就是mListView里面填充什么
mListView.setAdapter(new BaseListAdapter(this));
mListView就是类似下图的一条条数据的集合
然后跳转到 class
BaseListAdapter中去
如class
BaseListAdapter中的getCount函数负责统计listView的长度
根据这个长度,调用getView()逐一绘制每一行,如上图,getView()返回3,有3行ListView
继续谈class BaseListAdapter
getView函数绘制了每一行中的样子。上图就有图片,有文字,有按钮
咱们的getView函数中,有
viewHolder.img.setBackgroundResource((Integer)
getData().get(position).get("image"));
viewHolder.title.setText((CharSequence)
getData().get(position).get("title"));
final String path = (String)
getData().get(position).get("title");
也就是,1、设置图片get("image”),2、设置文字get("title"),
3、设置第一个按钮的动作——也就是,当点击按钮时候,程序会运行啥
viewHolder.button.setOnClickListener(new
View.OnClickListener()
具体来看,里面的代码,就是弹出一个小框,输出的文字是选定的文件的文件路径
4、设置第二个按钮的动作——也就是,点击按钮的时候,把这个文件删除
file.delete();把这个文件删除
下面这一部分还是在class
BaseListAdapter中
然后上面用到了一个重要的函数 getData()啥啥啥
比如,getData().get(position).get("title"))
意思就是拿到总的数据集合中的第position组数据,其中的名字叫title的数据的值(有点绕,多读几遍)
那getData()要做到什么呢?
——得到存在在黑名单中的文件路径
通过函数fileinBlackList()实现
上面的class
BaseListAdapter就是通过getData()函数获取的有毒文件路径
接着是整个的核心功能——扫描系统中的所有文件,匹配出存在在黑名单中的文件,返回文件路径
这个核心功能的函数入口就是,fileinBlackList()
接着,具体来看函数fileinBlackList()
1、getallfile(),获取系统所有文件的路径,和这个文件的MD5值
2、BlackList(),从黑名单文件中读取,所有有毒文件的MD5值
3、把 步骤1 中的MD5值 与 步骤2 中的MD5值
匹配比较,把MD5值存在在黑名单中的文件挑出来
然后核心函数,就被分解成俩了
1、getallfile()
2、BlackList()
一个一个看
先看第一个核心函数
getallfile(),
代码:只有四行
//获得外部存储的根目录
File dir =
Environment.getExternalStorageDirectory();
Map map = new
HashMap();
//调用遍历所有文件的方法
recursionFile(dir,map);
//返回文件路径集合
return map;
跟进去看
recursionFile()函数——遍历所有文件夹,找出所有文件名和文件路径
代码不贴了,大概意思就是
判断当前的文件路径,是不是文件夹:
如果是文件夹,那么继续调用recursionFile()函数
如果是文件,那么算出这个文件的MD5值——代码:fileMD5Sync(file.getAbsolutePath());并且把MD5值和文件路径存起来
然后这个算MD5值的函数——fileMD5Sync(file.getAbsolutePath());之后再提,先继续看这个被分解成两份的核心函数的第二个
第二个核心函数
BlackList()函数——找到放黑名单的文件(在res文件夹的raw文件夹中的a.txt),把其中的存放的所有MD5值都取出来,这个看函数代码好了,蛮简单的不提
然后基本完成了
功能框架都搭建起来了,
还剩一个小尾巴——算MD5值
直接看fileMD5Sync()函数,
这个看函数代码好了
算MD5值,这叫做套路代码,网上搜索“java
md5值计算”,就有好多的,找一个跑一跑试试,跑通了就直接上去用吧
还有第二个尾巴
发送信息给服务器
sendFileInBlackList()函数
这里,要明确,代码是这样实现的——手机端已经直接把MD5值算出来了,再把有毒文件的MD5值发给服务器,然后服务器那边显示相应的有毒文件的文件名和MD5值——换句话说,服务器就是一个显示的功能
上面所说的是代码是这样实现的,也达到了效果。至于最后文章里怎么写,都行。反正功能展示的出来,文章咋写都说的通的
继续sendFileInBlackList(),就是把有毒文件的《文件路径+文件MD5值》发过去,一句话完了。
另外,代码里面有一些程序并行机制什么的,也是学了好久才搞明白,实话说比较难,所以就干脆不提了(具体是class
GetThread在这个类的使用,具体来说就是,把发送信息给服务器这个功能放在后台运行,要不然按一下按钮过好久程序才有反应,这样效果就很不好了),并行机制在这里不重要,只是为了达到流畅运行效果的一种手段罢了,只需要知道有这么一回事就行,文章里也不用提到
这篇关于android 杀毒 源代码,android杀毒软件功能和代码分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!