热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

Android编程之杀毒的实现原理及具体实例

这篇文章主要介绍了Android编程之杀毒的实现原理及具体实例,结合实例形式分析了Android杀毒功能的原理与简单实现技巧,需要的朋友可以参考下

本文实例讲述了Android杀毒的实现原理。分享给大家供大家参考,具体如下:

一个杀毒软甲最核心的部分一个是病毒库一个是杀毒引擎,病毒库从服务器中获得,杀毒引擎实际上是判断程序中的包名和签名是否匹配病毒库中的包名和签名,如果匹配则为病毒,界面使用帧动画来显示。

思路:

1.从服务器端把病毒的版本库信息下载下来将解析的数据存放到List集合中
2.获取到手机中所有应用程序的包名以及程序的签名
3.将病毒库匹配手机应用程序包名及签名
4.用ScrollView标签进行自动滚动显示

关键代码如下:

特洛伊木马病毒库的信息:

<&#63;xml version="1.0" encoding="utf-8"&#63;>


 tory.virus
 
cn.itcast.virus

 
恶意软件,读取用户日志
 
3082020730820170a00302010202044ea7598f300d06092a864886f70d010105050030483
10a30080603550406130131310a30080603550408130131310a3008060355040713013131
0a3008060355040a130131310a3008060355040b130131310a30080603550403130131301
e170d3131313032363030353132375a170d3231313032333030353132375a3048310a3008
0603550406130131310a30080603550408130131310a30080603550407130131310a30080
60355040a130131310a3008060355040b130131310a3008060355040313013130819f300d
06092a864886f70d010101050003818d0030818902818100d915d7a98cde8bcd69b87ec52
11012ace847de42129a71bf679a059c2c55e893bc0ea886874432ab8b9097724211df6769
eacd3381ccac779ab7422d8101320b1e0b14e06ac8ee095b20e52cbe6163e10a87dc410b8
a91fb73d53c5bdb4a22d1295c61e04b8f8b68c475e69c1754a1dc35745e7c6ae0275c2620
b863b0d9ea8f0203010001300d06092a864886f70d01010505000381810038e1119fbb710
4180fddba4bc8b2c275df63f0df418b7480d8eba2891da20d34d3d083cfed7bb3eb546863
c76bc67cc93f2fa0e9377c470881c9a763c99cc035093184bb50f76e74155592eca3566a3
10af55e5fec19d6fdc1a74f226aef485f84389126e8e3f4b59fe2797cbfcac660b9f2cc81
e6f3dcaa7cb2001ecc496a7b
 



杀毒引擎:

/*
 * 杀毒引擎(下载病毒库、获取程序的包名及签名并进行匹配)
 * (non-Javadoc)
 * @see android.app.Activity#onTouchEvent(android.view.MotionEvent)
 */
@Override
public boolean onTouchEvent(MotionEvent event) {
 packagenames = new ArrayList();
 virusResult = new ArrayList();
 infos = new ArrayList();
 animationDrawable.start();//播放扫描病毒的动画
 new Thread(){
  @Override
  public void run() {
   try {
    URL url = new URL("http://192.168.1.168:8080/virus.xml");
    HttpURLConnection cOnn= (HttpURLConnection) url.openConnection();
    InputStream is = conn.getInputStream();
    //从服务器解析病毒库并获取到病毒库的集合
    virusbeans = VirusInfo.getVirusInfos(is);
    TaskInfo taskInfo = new TaskInfo(KillVirusActivity.this); //实例化包资源管理器
    //获取到当前手机里面所有的包名
    infos = pm.getInstalledApplications(0);
    for(ApplicationInfo info : infos ){
     packagenames.add(info.packageName);
    }
    int count=0;
    // 杀毒引擎 根据病毒库 比对当前系统里面的程序包名 签名进行 杀毒
    StringBuilder sb = new StringBuilder();
    for(String packname : packagenames){
     sb.append("正在扫描 "+ packname);
     sb.append("\n");
     Message msg = new Message();
     msg.what = SCANNING;
     msg.obj = sb;
     handler.sendMessage(msg);
     //检查当前的packname 和对应签名 是不是跟病毒库里面的信息一样
     for(VirusBean virusbean : virusbeans){
      if(packname.equals(virusbean.getPackname())&&
        taskInfo.getAppSignature(packname).equals(virusbean.getSignature()))
      {
       virusResult.add(packname);//添加一个病毒
      }
     }
     count ++;//记录病毒的总数
    }
    Message msg = new Message();
    msg.what = SCANNING_FINISH;
    msg.obj = count;
    handler.sendMessage(msg);
   } catch (Exception e) {
    e.printStackTrace();
   }
  }
 }.start();
 return super.onTouchEvent(event);
}

显示病毒扫描信息:

Handler handler = new Handler(){
 @Override
 public void handleMessage(Message msg) {
  super.handleMessage(msg);
  switch (msg.what) {
  case SCANNING:
   StringBuilder sb = (StringBuilder) msg.obj;
   tv_killvirus_info.setText(sb.toString());
   sv.scrollBy(0, 25);//每次增加都会自动向下移动画面
   break;
  case SCANNING_FINISH:
   int i = (Integer) msg.obj;
   StringBuilder sb1 = new StringBuilder();
   sb1.append("扫描完毕 共扫描 "+ i+ " 个程序");
   if(virusResult.size()>0){
    sb1.append("发现病毒 \n");
     for(String packname : virusResult){
      sb1.append("病毒名"+ packname);
      sb1.append("\n");
     }
    }
    tv_killvirus_info.setText(sb1.toString());
    animationDrawable.stop();
   break;
  }
 }
};

获取到程序的签名:

/*
 * 获取程序的签名
 */
public String getAppSignature(String packname){
  try {
   PackageInfo packinfo =pm.getPackageInfo(packname, PackageManager.GET_SIGNATURES);
   //获取到所有的权限
   return packinfo.signatures[0].toCharsString();
  } catch (NameNotFoundException e) {
   e.printStackTrace();
   return null;
  }
}

显示扫描的文件页面并自动滚动:





希望本文所述对大家Android程序设计有所帮助。


推荐阅读
  • 本文探讨了Web开发与游戏开发之间的主要区别,旨在帮助开发者更好地理解两种开发领域的特性和需求。文章基于作者的实际经验和网络资料整理而成。 ... [详细]
  • 在Linux系统上构建Web服务器的详细步骤
    本文详细介绍了如何在Linux系统上搭建Web服务器的过程,包括安装Apache、PHP和MySQL等关键组件,以及遇到的一些常见问题及其解决方案。 ... [详细]
  • 本文探讨了如何通过WebBrowser控件在用户点击输入框时自动显示图片验证码。该过程可能涉及JavaScript事件的触发与响应。 ... [详细]
  • 本文详细介绍了如何在Android应用中使用GridView组件以网格形式展示数据(如文本和图像)。通过行列布局,实现类似矩阵的数据展示效果。 ... [详细]
  • 在使用Maven进行项目构建时,由于依赖库的下载速度慢常常让人感到沮丧,这直接影响了开发效率和学习热情。幸运的是,阿里云提供了一个快速的国内镜像服务,能够显著提升Maven项目的构建速度。 ... [详细]
  • 本文介绍了在Android项目中实现时间轴效果的方法,通过自定义ListView的Item布局和适配器逻辑,实现了动态显示和隐藏时间标签的功能。文中详细描述了布局文件、适配器代码以及时间格式化工具类的具体实现。 ... [详细]
  • JavaWeb技术架构解析
    本文探讨了JavaWeb开发中客户端与服务器端的交互模式,重点分析了B/S(浏览器/服务器)和C/S(客户端/服务器)两种架构的特点及应用场景。 ... [详细]
  • Android中实现复合旋转动画效果
    本文将探讨如何在Android应用中实现动态且吸引人的旋转动画。通过结合多种动画类型,如透明度变化、旋转、缩放和位移,可以创造出更为复杂的视觉效果。我们将从XML布局和Java代码两个方面进行详细介绍。 ... [详细]
  • Android商城应用开发指南(第二部分):创建启动欢迎页
    大多数商城应用程序在启动时会显示一个欢迎页面,以提升用户体验。本文将指导您如何实现一个基本的欢迎页,该页面会在用户打开应用后短暂展示,随后自动跳转至主界面。 ... [详细]
  • 本文详细介绍了如何使用 PHP 编程语言输出 99 乘法表,包括使用不同的循环结构如 do-while、for 循环等方法,并提供了具体的代码示例。 ... [详细]
  • 深入解析SSL Strip攻击机制
    本文详细介绍了SSL Strip(一种网络攻击形式)的工作原理及其对网络安全的影响。通过分析SSL与HTTPS的基本概念,探讨了SSL Strip如何利用某些网站的安全配置不足,实现中间人攻击,以及如何防范此类攻击。 ... [详细]
  • 使用LVS与ldirectord实现高可用负载均衡
    本文介绍了如何通过LVS(Linux Virtual Server)结合ldirectord工具来实现服务器的健康检查及负载均衡功能。环境设置包括一个LVS节点和两个真实服务器节点,通过配置ldirectord进行健康状态监测,确保系统的高可用性。 ... [详细]
  • MySQL性能测试标准倡议:老叶提出的压测基准
    进行MySQL的压力测试通常是为了评估新旧版本之间的性能差异、验证硬件升级的效果、测试参数调整的影响以及评估新业务的负载承受能力。老叶提出了一个MySQL压力测试基准值倡议,旨在促进行业内的标准化和成果共享。 ... [详细]
  • APM(Application Performance Management,应用性能管理)对于提供互联网服务的企业至关重要。本文将深入探讨APM如何帮助识别和解决导致用户流失的技术问题,以及它在提升整体用户体验方面的作用。 ... [详细]
  • Redis安全防护深入解析
    本文详细探讨了如何通过指令安全、端口管理和SSL代理等措施有效保护Redis服务的安全性。 ... [详细]
author-avatar
雄鹰访谈录
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有