前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >APK检测管理系统 毕业设计 JAVA+Vue+SpringBoot+MySQL

APK检测管理系统 毕业设计 JAVA+Vue+SpringBoot+MySQL

作者头像
Designer 小郑
发布2023-10-17 18:49:02
2600
发布2023-10-17 18:49:02
举报
文章被收录于专栏:跟着小郑学JAVA跟着小郑学JAVA

作者主页Designer 小郑 作者简介:3年JAVA全栈开发经验,专注JAVA技术、系统定制、远程指导,致力于企业数字化转型,CSDN博客专家,阿里云社区专家博主,蓝桥云课讲师。

\color{red}{项目编号:S038,源码已在 Github 中托管,需要的朋友请自行下载。}
代码语言:javascript
复制
https://github.com/yyzwz/allProject
在这里插入图片描述
在这里插入图片描述

一、摘要

1.1 项目介绍

基于JAVA+Vue+SpringBoot+MySQL的APK检测管理系统,包含了软件档案模块、软件检测模块、软件举报模块、开放平台模块,还包含系统自带的用户管理、部门管理、角色管理、菜单管理、日志管理、数据字典管理、文件管理、图表展示等基础模块,APK检测管理系统基于角色的访问控制,给软件管理员、普通用户使用,可将权限精确到按钮级别,您可以自定义角色并分配权限,系统适合设计精确的权限约束需求。

随着移动应用的迅猛发展,APK文件的数量和复杂性日益增加,给应用市场的安全性和稳定性带来了巨大挑战。为了提高APK文件的检测效率和准确性,本论文提出了一种基于大数据和机器学习的APK检测系统。该系统利用大数据技术对海量的APK文件进行收集和存储,并采用特征提取和特征选择方法对APK文件进行表征。通过构建一个深度学习模型,对APK文件进行分类和检测,以识别潜在的恶意软件和安全隐患。实验结果表明,该系统在APK检测的准确性和效率方面表现出色,对于提高移动应用的安全性具有重要意义。

1.2 项目录屏


二、功能模块

APK检测系统的功能性需求主要包含数据中心模块、开放平台模块、软件档案模块、软件检测模块、软件举报模块这五大模块,系统是基于浏览器运行的web管理后端,其中各个模块详细说明如下。

在这里插入图片描述
在这里插入图片描述

2.1 数据中心模块

数据中心模块包含了APK检测系统的系统基础配置,如登录用户的管理、运营公司组织架构的管理、用户菜单权限的管理、系统日志的管理、公用文件云盘的管理。 其中登录用户管理模块,由管理员负责运维工作,管理员可以对登录用户进行增加、删除、修改、查询操作。 组织架构,指的是高校的组织架构,该模块适用于管理这些组织架构的部门层级和教师的部门归属情况。 用户菜单权限管理模块,用于管理不同权限的用户,拥有哪些具体的菜单权限。 系统日志的管理,用于维护用户登入系统的记录,方便定位追踪用户的操作情况。 公用云盘管理模块,用于统一化维护APK检测系统中的图片,如合同签订文件、合同照片等等。

2.2 开放平台模块

开放平台是一种三方接口平台,支持其他用户通过API接口的方式调用系统功能,开放平台的数据包括主体名称、主体介绍、应用ID、密匙、创建人、创建时间、更新人、更新时间,管理员可以新增、删除、编辑和条件查询开放平台数据,用户可以查询管理员发布的开放平台数据。

2.3 软件档案模块

软件是APK检测系统的核心实体,需要建立软件档案模块对用户发布的软件进行管理,软件档案的字段包括软件名称、软件介绍、开发者、文件、创建人、创建时间、更新人、更新时间,管理员可以新增、删除、编辑和条件查询软件数据,用户可以查询管理员发布的软件数据,且可以上传自己的软件。

2.4 软件检测模块

有了软件档案之后,就需要对软件进行检测,用户提交软件检测申请后,保存在软件检测模块,软件检测的字段包括软件ID、软件名称、软件介绍、开发者、检测状态、检测时间、检测人、检测结论,管理员收到用户的软件检测申请后进行检测,并将检测结论录入到系统中。

2.5 软件举报模块

除了用于提交软件检测申请之外,还支持用户直接举报软件,管理员对齐进行判定,举报的数据存储在软件举报模块中,软件举报字段包括软件ID、软件名称、软件介绍、开发者、举报内容、处理结果、处理人、处理时间,用户可以提交软件举报申请,管理员对用户举报的申请订单进行核实。


三、系统设计

3.1 用例设计

UML是面向对象的图形化建模语言,具有表示容易,定义友好,适用范畴广泛,功能强大。用例图是用例模型的一种,需求分析人员可采用用例图表示用户操作行为。APK检测系统的用例图设计主要包括用户用例设计和管理员用例设计。

在这里插入图片描述
在这里插入图片描述

3.2 数据库设计

3.2.1 开放平台表
在这里插入图片描述
在这里插入图片描述
3.2.2 软件档案表
在这里插入图片描述
在这里插入图片描述
3.2.3 软件检测表
在这里插入图片描述
在这里插入图片描述
3.2.4 软件举报表
在这里插入图片描述
在这里插入图片描述

四、系统展示

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

五、核心代码

5.1 查询开放平台

代码语言:javascript
复制
@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询开放平台")
public Result<IPage<OpenPlatform>> getByPage(@ModelAttribute OpenPlatform openPlatform ,@ModelAttribute PageVo page){
    QueryWrapper<OpenPlatform> qw = new QueryWrapper<>();
    User currUser = securityUtil.getCurrUser();
    QueryWrapper<User> userQw = new QueryWrapper<>();
    userQw.eq("id",currUser.getId());
    userQw.inSql("id","SELECT user_id FROM a_user_role WHERE del_flag = 0 AND role_id = '1536606659751841799'");
    if(iUserService.count(userQw) < 1L) {
        qw.eq("user_id",currUser.getId());
    }
    if(!ZwzNullUtils.isNull(openPlatform.getTitle())) {
        qw.like("title",openPlatform.getTitle());
    }
    if(!ZwzNullUtils.isNull(openPlatform.getStatus())) {
        qw.eq("status",openPlatform.getStatus());
    }
    IPage<OpenPlatform> data = iOpenPlatformService.page(PageUtil.initMpPage(page),qw);
    return new ResultUtil<IPage<OpenPlatform>>().setData(data);
}

5.2 新增开放平台

代码语言:javascript
复制
@RequestMapping(value = "/insert", method = RequestMethod.POST)
@ApiOperation(value = "新增开放平台")
public Result<OpenPlatform> insert(OpenPlatform openPlatform){
    User currUser = securityUtil.getCurrUser();
    openPlatform.setUserId(currUser.getId());
    openPlatform.setTime(DateUtil.now());
    Random r = new Random();
    int ranInt = r.nextInt(90000) + 10000;
    openPlatform.setAppid(ranInt + "");
    openPlatform.setSecret(UUID.randomUUID().toString());
    iOpenPlatformService.saveOrUpdate(openPlatform);
    return new ResultUtil<OpenPlatform>().setData(openPlatform);
}

5.3 查询软件档案

代码语言:javascript
复制
@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询软件档案")
public Result<IPage<Software>> getByPage(@ModelAttribute Software software ,@ModelAttribute PageVo page){
    QueryWrapper<Software> qw = new QueryWrapper<>();
    User currUser = securityUtil.getCurrUser();
    QueryWrapper<User> userQw = new QueryWrapper<>();
    userQw.eq("id",currUser.getId());
    userQw.inSql("id","SELECT user_id FROM a_user_role WHERE del_flag = 0 AND role_id = '1536606659751841799'");
    if(iUserService.count(userQw) < 1L) {
        qw.eq("user_id",currUser.getId());
    }
    if(!ZwzNullUtils.isNull(software.getTitle())) {
        qw.like("title",software.getTitle());
    }
    if(!ZwzNullUtils.isNull(software.getContent())) {
        qw.like("content",software.getContent());
    }
    IPage<Software> data = iSoftwareService.page(PageUtil.initMpPage(page),qw);
    return new ResultUtil<IPage<Software>>().setData(data);
}

5.4 新增软件举报

代码语言:javascript
复制
@RequestMapping(value = "/insert", method = RequestMethod.POST)
@ApiOperation(value = "新增软件举报")
public Result<SoftwareReport> insert(SoftwareReport softwareReport){
    Software s = iSoftwareService.getById(softwareReport.getSoftId());
    if(s == null) {
        return ResultUtil.error("软件不存在");
    }
    User currUser = securityUtil.getCurrUser();
    softwareReport.setUserId(currUser.getId());
    softwareReport.setTitle(s.getTitle());
    softwareReport.setContent(s.getContent());
    softwareReport.setDeveloper(s.getDeveloper());
    softwareReport.setFileUrl(s.getFileUrl());
    softwareReport.setWorkResult("");
    softwareReport.setWorkUser("");
    softwareReport.setWorkTime("");
    iSoftwareReportService.saveOrUpdate(softwareReport);
    return new ResultUtil<SoftwareReport>().setData(softwareReport);
}

5.5 新增软件检测

代码语言:javascript
复制
@RequestMapping(value = "/addOne", method = RequestMethod.POST)
@ApiOperation(value = "新增软件检测")
public Result<SoftwareCheck> addOne(@RequestParam String id){
    Software s = iSoftwareService.getById(id);
    if(s == null) {
        return ResultUtil.error("软件不存在");
    }
    SoftwareCheck softwareCheck = new SoftwareCheck();
    softwareCheck.setTitle(s.getTitle());
    softwareCheck.setContent(s.getContent());
    softwareCheck.setDeveloper(s.getDeveloper());
    softwareCheck.setFileUrl(s.getFileUrl());
    softwareCheck.setStatus("未检测");
    softwareCheck.setCheckTime("");
    softwareCheck.setCheckUser("");
    softwareCheck.setCheckResult("");
    iSoftwareCheckService.saveOrUpdate(softwareCheck);
    return new ResultUtil<SoftwareCheck>().setData(softwareCheck);
}

六、免责说明

  • 本项目仅供个人学习使用,商用授权请联系博主,否则后果自负。
  • 博主拥有本软件构建后的应用系统全部内容所有权及独立的知识产权,拥有最终解释权。
  • 如有问题,欢迎在仓库 Issue 留言,看到后会第一时间回复,相关意见会酌情考虑,但没有一定被采纳的承诺或保证。

下载本系统代码或使用本系统的用户,必须同意以下内容,否则请勿下载!

  1. 出于自愿而使用/开发本软件,了解使用本软件的风险,且同意自己承担使用本软件的风险。
  2. 利用本软件构建的网站的任何信息内容以及导致的任何版权纠纷和法律争议及后果和博主无关,博主对此不承担任何责任。
  3. 在任何情况下,对于因使用或无法使用本软件而导致的任何难以合理预估的损失(包括但不仅限于商业利润损失、业务中断与业务信息丢失),博主概不承担任何责任。
  4. 必须了解使用本软件的风险,博主不承诺提供一对一的技术支持、使用担保,也不承担任何因本软件而产生的难以预料的问题的相关责任。
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2023-10-14,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、摘要
    • 1.1 项目介绍
      • 1.2 项目录屏
      • 二、功能模块
        • 2.1 数据中心模块
          • 2.2 开放平台模块
            • 2.3 软件档案模块
              • 2.4 软件检测模块
                • 2.5 软件举报模块
                • 三、系统设计
                  • 3.1 用例设计
                    • 3.2 数据库设计
                      • 3.2.1 开放平台表
                      • 3.2.2 软件档案表
                      • 3.2.3 软件检测表
                      • 3.2.4 软件举报表
                  • 四、系统展示
                  • 五、核心代码
                    • 5.1 查询开放平台
                      • 5.2 新增开放平台
                        • 5.3 查询软件档案
                          • 5.4 新增软件举报
                            • 5.5 新增软件检测
                            • 六、免责说明
                            相关产品与服务
                            云数据库 MySQL
                            腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
                            领券
                            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档