news 2026/5/21 11:19:15

员工绩效考核|基于Springboot的员工绩效考核管理系统设计与实现(源码+数据库+文档)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
员工绩效考核|基于Springboot的员工绩效考核管理系统设计与实现(源码+数据库+文档)

员工绩效考核管理系统

目录

基于Springboot的员工绩效考核管理系统设计与实现

一、前言

二、系统功能设计

三、系统实现

4.1.1系统登录模块实现

4.1.2个人中心管理功能模块实现

4.1.3部门信息管理模块实现

4.1.4部门信息管理模块实现

4.1.5绩效指标管理模块实现

4.1.6公告信息管理模块的实现

4.1.7岗位管理模块的实现

4.1.8绩效考核管理模块的实现

四、数据库设计

1、实体ER图

五、核心代码

六、论文参考

七、最新计算机毕设选题推荐

八、源码获取:


博主介绍:✌️大厂码农|毕设布道师,阿里云开发社区乘风者计划专家博主,CSDN平台Java领域优质创作者,专注于大学生项目实战开发、讲解和毕业答疑辅导。✌️

主要项目:小程序、SpringBoot、SSM、Vue、Html、Jsp、Nodejs等设计与开发。

🍅文末获取源码联系🍅

基于Springboot的员工绩效考核管理系统设计与实现

一、前言

基于javaweb的员工绩效考核系统,本系统为员工绩效考核管理系统,助企业衡量和提升员工绩效基于Spring Boot的企业员工绩效考核管理系统本月度员工绩效考核管理系统采用java语言做为代码编写工具,本系统为月度员工绩效考核管理系统,绩效考核管理系统的产生,是专为企业开发的对员工考核的协助软件。可以帮助企业对于员工的绩效考核进行更为正规、规范的管理,使企业管理更加的轻松快捷,本月度员工绩效考核管理系统采用java语言做为代码编写工具,采用mysql数据库进行系统中信息的存储与处理。框架采用springboot。本月度员工绩效考核管理系统调试环境为myeclipse,服务器为tomcat。主要包括的内容有部门方面、员工方面、绩效考核方面、绩效指标方面。员工可以查询绩效指标和绩效考核详情,管理员进行发布和管理。本系统结合了新时代的工作要求和获得了先进技术的支持,适应时代发展,为使用人员提供了极好的绩效考核途径。

关键词:部门管理;绩效指标管理;绩效考核管理;springboot框架

二、系统功能设计

根据系统分析中分析出来的功能,本系统的主要功能包括部门管理、岗位管理、绩效指标管理、绩效考核管理、员工管理、通知管理等。本系统的功能结构设计如下图3.1所示:

三、系统实现

4.1.1系统登录模块实现

本模块界面加入了系统标题和角色的选择,在本界面中采用了图形和控件进行合理摆放的方法进行设计,还加入了合适的背景图片,使登录界面更加的直观。系统登录模块设计实现界面如下图4.1所示:

图4.1系统登录模块界面实现

4.1.2个人中心管理功能模块实现

本界面主要是对管理员账号和密码进行设置,是管理员角色的操作功能,员工不能添加管理员账号,个人中心管理功能实现界面如下图4.2所示:

图4.2个人中心管理模块实现界面

4.1.3部门信息管理模块实现

部门信息是管理员角色的功能,管理员可以为企业添加新的部门,可以查询部门的创建时间,管理员添加部门信息的实现界面如下图4.3所示:

图4.3管理员添加部门信息实现界面

管理员添加部门信息的流程为,先进行必要字段的填写,数据库进行判定是否合法、是否为空,然后进行数据库信息的插入。

4.1.4部门信息管理模块实现

管理员可以在新员工招入时进行添加,对员工进行部门的安排和备注的添加。管理员添加员工信息的界面实现如下图4.4所示:

图4.4管理员添加员工信息界面实现

4.1.5绩效指标管理模块实现

本功能是为了方便管理员对员工进行绩效考核,添加绩效指标的实现界面如下图4.5所示:

图4.5添加绩效指标模块的界面实现

4.1.6公告信息管理模块的实现

本功能可以实现公告的发布,添加公告信息功能模块的实现界面如下图4.6所示:

图4.6添加公告模块的实现界面

4.1.7岗位管理模块的实现

管理员可以对员工分配岗位,管理员查询岗位的实现界面如下图4.7所示:

图4.7查询岗位信息的实现界面

4.1.8绩效考核管理模块的实现

发布员工的绩效考核,绩效考核信息的实现界面如下图4.8所示:

图4.8绩效考核信息界面

4.2员工功能的界面实现

员工可以查询公告和绩效指标、绩效考核信息,也可以修改个人资料和密码。实现界面如下图4.9所示:

图4.9员工功能的实现界面

四、数据库设计

1、实体ER图

(1)管理员实体的Er图如下图3.2所示:

图3.2管理员Er图

(2)管理员管理的员工信息ER图如图3.3所示。

图3.3员工信息ER图

(3)企业中部门信息ER图如图3.4所示:

图3.4部门信息ER图

五、核心代码

package com.controller; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Arrays; import java.util.Calendar; import java.util.Map; import java.util.HashMap; import java.util.Iterator; import java.util.Date; import java.util.List; import javax.servlet.http.HttpServletRequest; import com.utils.ValidatorUtils; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.format.annotation.DateTimeFormat; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.baomidou.mybatisplus.mapper.Wrapper; import com.annotation.IgnoreAuth; import com.entity.BumenEntity; import com.entity.view.BumenView; import com.service.BumenService; import com.service.TokenService; import com.utils.PageUtils; import com.utils.R; import com.utils.MD5Util; import com.utils.MPUtil; import com.utils.CommonUtil; /** * 部门 * 后端接口 * @author * @email * @date 2021-05-07 10:42:31 */ @RestController @RequestMapping("/bumen") public class BumenController { @Autowired private BumenService bumenService; /** * 后端列表 */ @RequestMapping("/page") public R page(@RequestParam Map<String, Object> params,BumenEntity bumen, HttpServletRequest request){ EntityWrapper<BumenEntity> ew = new EntityWrapper<BumenEntity>(); PageUtils page = bumenService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, bumen), params), params)); return R.ok().put("data", page); } /** * 前端列表 */ @RequestMapping("/list") public R list(@RequestParam Map<String, Object> params,BumenEntity bumen, HttpServletRequest request){ EntityWrapper<BumenEntity> ew = new EntityWrapper<BumenEntity>(); PageUtils page = bumenService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, bumen), params), params)); return R.ok().put("data", page); } /** * 列表 */ @RequestMapping("/lists") public R list( BumenEntity bumen){ EntityWrapper<BumenEntity> ew = new EntityWrapper<BumenEntity>(); ew.allEq(MPUtil.allEQMapPre( bumen, "bumen")); return R.ok().put("data", bumenService.selectListView(ew)); } /** * 查询 */ @RequestMapping("/query") public R query(BumenEntity bumen){ EntityWrapper< BumenEntity> ew = new EntityWrapper< BumenEntity>(); ew.allEq(MPUtil.allEQMapPre( bumen, "bumen")); BumenView bumenView = bumenService.selectView(ew); return R.ok("查询部门成功").put("data", bumenView); } /** * 后端详情 */ @RequestMapping("/info/{id}") public R info(@PathVariable("id") Long id){ BumenEntity bumen = bumenService.selectById(id); return R.ok().put("data", bumen); } /** * 前端详情 */ @RequestMapping("/detail/{id}") public R detail(@PathVariable("id") Long id){ BumenEntity bumen = bumenService.selectById(id); return R.ok().put("data", bumen); } /** * 后端保存 */ @RequestMapping("/save") public R save(@RequestBody BumenEntity bumen, HttpServletRequest request){ bumen.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(bumen); bumenService.insert(bumen); return R.ok(); } /** * 前端保存 */ @RequestMapping("/add") public R add(@RequestBody BumenEntity bumen, HttpServletRequest request){ bumen.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(bumen); bumenService.insert(bumen); return R.ok(); } /** * 修改 */ @RequestMapping("/update") public R update(@RequestBody BumenEntity bumen, HttpServletRequest request){ //ValidatorUtils.validateEntity(bumen); bumenService.updateById(bumen);//全部更新 return R.ok(); } /** * 删除 */ @RequestMapping("/delete") public R delete(@RequestBody Long[] ids){ bumenService.deleteBatchIds(Arrays.asList(ids)); return R.ok(); } /** * 提醒接口 */ @RequestMapping("/remind/{columnName}/{type}") public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request, @PathVariable("type") String type,@RequestParam Map<String, Object> map) { map.put("column", columnName); map.put("type", type); if(type.equals("2")) { SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); Calendar c = Calendar.getInstance(); Date remindStartDate = null; Date remindEndDate = null; if(map.get("remindstart")!=null) { Integer remindStart = Integer.parseInt(map.get("remindstart").toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindStart); remindStartDate = c.getTime(); map.put("remindstart", sdf.format(remindStartDate)); } if(map.get("remindend")!=null) { Integer remindEnd = Integer.parseInt(map.get("remindend").toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindEnd); remindEndDate = c.getTime(); map.put("remindend", sdf.format(remindEndDate)); } } Wrapper<BumenEntity> wrapper = new EntityWrapper<BumenEntity>(); if(map.get("remindstart")!=null) { wrapper.ge(columnName, map.get("remindstart")); } if(map.get("remindend")!=null) { wrapper.le(columnName, map.get("remindend")); } int count = bumenService.selectCount(wrapper); return R.ok().put("count", count); } } package com.controller; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Arrays; import java.util.Calendar; import java.util.Map; import java.util.HashMap; import java.util.Iterator; import java.util.Date; import java.util.List; import javax.servlet.http.HttpServletRequest; import com.utils.ValidatorUtils; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.format.annotation.DateTimeFormat; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.baomidou.mybatisplus.mapper.Wrapper; import com.annotation.IgnoreAuth; import com.entity.GangweiEntity; import com.entity.view.GangweiView; import com.service.GangweiService; import com.service.TokenService; import com.utils.PageUtils; import com.utils.R; import com.utils.MD5Util; import com.utils.MPUtil; import com.utils.CommonUtil; /** * 岗位 * 后端接口 * @author * @email * @date 2021-05-07 10:42:31 */ @RestController @RequestMapping("/gangwei") public class GangweiController { @Autowired private GangweiService gangweiService; /** * 后端列表 */ @RequestMapping("/page") public R page(@RequestParam Map<String, Object> params,GangweiEntity gangwei, HttpServletRequest request){ EntityWrapper<GangweiEntity> ew = new EntityWrapper<GangweiEntity>(); PageUtils page = gangweiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, gangwei), params), params)); return R.ok().put("data", page); } /** * 前端列表 */ @RequestMapping("/list") public R list(@RequestParam Map<String, Object> params,GangweiEntity gangwei, HttpServletRequest request){ EntityWrapper<GangweiEntity> ew = new EntityWrapper<GangweiEntity>(); PageUtils page = gangweiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, gangwei), params), params)); return R.ok().put("data", page); } /** * 列表 */ @RequestMapping("/lists") public R list( GangweiEntity gangwei){ EntityWrapper<GangweiEntity> ew = new EntityWrapper<GangweiEntity>(); ew.allEq(MPUtil.allEQMapPre( gangwei, "gangwei")); return R.ok().put("data", gangweiService.selectListView(ew)); } /** * 查询 */ @RequestMapping("/query") public R query(GangweiEntity gangwei){ EntityWrapper< GangweiEntity> ew = new EntityWrapper< GangweiEntity>(); ew.allEq(MPUtil.allEQMapPre( gangwei, "gangwei")); GangweiView gangweiView = gangweiService.selectView(ew); return R.ok("查询岗位成功").put("data", gangweiView); } /** * 后端详情 */ @RequestMapping("/info/{id}") public R info(@PathVariable("id") Long id){ GangweiEntity gangwei = gangweiService.selectById(id); return R.ok().put("data", gangwei); } /** * 前端详情 */ @RequestMapping("/detail/{id}") public R detail(@PathVariable("id") Long id){ GangweiEntity gangwei = gangweiService.selectById(id); return R.ok().put("data", gangwei); } /** * 后端保存 */ @RequestMapping("/save") public R save(@RequestBody GangweiEntity gangwei, HttpServletRequest request){ gangwei.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(gangwei); gangweiService.insert(gangwei); return R.ok(); } /** * 前端保存 */ @RequestMapping("/add") public R add(@RequestBody GangweiEntity gangwei, HttpServletRequest request){ gangwei.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(gangwei); gangweiService.insert(gangwei); return R.ok(); } /** * 修改 */ @RequestMapping("/update") public R update(@RequestBody GangweiEntity gangwei, HttpServletRequest request){ //ValidatorUtils.validateEntity(gangwei); gangweiService.updateById(gangwei);//全部更新 return R.ok(); } /** * 删除 */ @RequestMapping("/delete") public R delete(@RequestBody Long[] ids){ gangweiService.deleteBatchIds(Arrays.asList(ids)); return R.ok(); } /** * 提醒接口 */ @RequestMapping("/remind/{columnName}/{type}") public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request, @PathVariable("type") String type,@RequestParam Map<String, Object> map) { map.put("column", columnName); map.put("type", type); if(type.equals("2")) { SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); Calendar c = Calendar.getInstance(); Date remindStartDate = null; Date remindEndDate = null; if(map.get("remindstart")!=null) { Integer remindStart = Integer.parseInt(map.get("remindstart").toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindStart); remindStartDate = c.getTime(); map.put("remindstart", sdf.format(remindStartDate)); } if(map.get("remindend")!=null) { Integer remindEnd = Integer.parseInt(map.get("remindend").toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindEnd); remindEndDate = c.getTime(); map.put("remindend", sdf.format(remindEndDate)); } } Wrapper<GangweiEntity> wrapper = new EntityWrapper<GangweiEntity>(); if(map.get("remindstart")!=null) { wrapper.ge(columnName, map.get("remindstart")); } if(map.get("remindend")!=null) { wrapper.le(columnName, map.get("remindend")); } int count = gangweiService.selectCount(wrapper); return R.ok().put("count", count); } } package com.controller; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Arrays; import java.util.Calendar; import java.util.Map; import java.util.HashMap; import java.util.Iterator; import java.util.Date; import java.util.List; import javax.servlet.http.HttpServletRequest; import com.utils.ValidatorUtils; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.format.annotation.DateTimeFormat; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.baomidou.mybatisplus.mapper.Wrapper; import com.annotation.IgnoreAuth; import com.entity.JixiaokaoheEntity; import com.entity.view.JixiaokaoheView; import com.service.JixiaokaoheService; import com.service.TokenService; import com.utils.PageUtils; import com.utils.R; import com.utils.MD5Util; import com.utils.MPUtil; import com.utils.CommonUtil; /** * 绩效考核 * 后端接口 * @author * @email * @date 2021-05-07 10:42:31 */ @RestController @RequestMapping("/jixiaokaohe") public class JixiaokaoheController { @Autowired private JixiaokaoheService jixiaokaoheService; /** * 后端列表 */ @RequestMapping("/page") public R page(@RequestParam Map<String, Object> params,JixiaokaoheEntity jixiaokaohe, HttpServletRequest request){ String tableName = request.getSession().getAttribute("tableName").toString(); if(tableName.equals("yuangong")) { jixiaokaohe.setYuangonggonghao((String)request.getSession().getAttribute("username")); } EntityWrapper<JixiaokaoheEntity> ew = new EntityWrapper<JixiaokaoheEntity>(); PageUtils page = jixiaokaoheService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jixiaokaohe), params), params)); return R.ok().put("data", page); } /** * 前端列表 */ @RequestMapping("/list") public R list(@RequestParam Map<String, Object> params,JixiaokaoheEntity jixiaokaohe, HttpServletRequest request){ EntityWrapper<JixiaokaoheEntity> ew = new EntityWrapper<JixiaokaoheEntity>(); PageUtils page = jixiaokaoheService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jixiaokaohe), params), params)); return R.ok().put("data", page); } /** * 列表 */ @RequestMapping("/lists") public R list( JixiaokaoheEntity jixiaokaohe){ EntityWrapper<JixiaokaoheEntity> ew = new EntityWrapper<JixiaokaoheEntity>(); ew.allEq(MPUtil.allEQMapPre( jixiaokaohe, "jixiaokaohe")); return R.ok().put("data", jixiaokaoheService.selectListView(ew)); } /** * 查询 */ @RequestMapping("/query") public R query(JixiaokaoheEntity jixiaokaohe){ EntityWrapper< JixiaokaoheEntity> ew = new EntityWrapper< JixiaokaoheEntity>(); ew.allEq(MPUtil.allEQMapPre( jixiaokaohe, "jixiaokaohe")); JixiaokaoheView jixiaokaoheView = jixiaokaoheService.selectView(ew); return R.ok("查询绩效考核成功").put("data", jixiaokaoheView); } /** * 后端详情 */ @RequestMapping("/info/{id}") public R info(@PathVariable("id") Long id){ JixiaokaoheEntity jixiaokaohe = jixiaokaoheService.selectById(id); return R.ok().put("data", jixiaokaohe); } /** * 前端详情 */ @RequestMapping("/detail/{id}") public R detail(@PathVariable("id") Long id){ JixiaokaoheEntity jixiaokaohe = jixiaokaoheService.selectById(id); return R.ok().put("data", jixiaokaohe); } /** * 后端保存 */ @RequestMapping("/save") public R save(@RequestBody JixiaokaoheEntity jixiaokaohe, HttpServletRequest request){ jixiaokaohe.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(jixiaokaohe); jixiaokaoheService.insert(jixiaokaohe); return R.ok(); } /** * 前端保存 */ @RequestMapping("/add") public R add(@RequestBody JixiaokaoheEntity jixiaokaohe, HttpServletRequest request){ jixiaokaohe.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(jixiaokaohe); jixiaokaoheService.insert(jixiaokaohe); return R.ok(); } /** * 修改 */ @RequestMapping("/update") public R update(@RequestBody JixiaokaoheEntity jixiaokaohe, HttpServletRequest request){ //ValidatorUtils.validateEntity(jixiaokaohe); jixiaokaoheService.updateById(jixiaokaohe);//全部更新 return R.ok(); } /** * 删除 */ @RequestMapping("/delete") public R delete(@RequestBody Long[] ids){ jixiaokaoheService.deleteBatchIds(Arrays.asList(ids)); return R.ok(); } /** * 提醒接口 */ @RequestMapping("/remind/{columnName}/{type}") public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request, @PathVariable("type") String type,@RequestParam Map<String, Object> map) { map.put("column", columnName); map.put("type", type); if(type.equals("2")) { SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); Calendar c = Calendar.getInstance(); Date remindStartDate = null; Date remindEndDate = null; if(map.get("remindstart")!=null) { Integer remindStart = Integer.parseInt(map.get("remindstart").toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindStart); remindStartDate = c.getTime(); map.put("remindstart", sdf.format(remindStartDate)); } if(map.get("remindend")!=null) { Integer remindEnd = Integer.parseInt(map.get("remindend").toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindEnd); remindEndDate = c.getTime(); map.put("remindend", sdf.format(remindEndDate)); } } Wrapper<JixiaokaoheEntity> wrapper = new EntityWrapper<JixiaokaoheEntity>(); if(map.get("remindstart")!=null) { wrapper.ge(columnName, map.get("remindstart")); } if(map.get("remindend")!=null) { wrapper.le(columnName, map.get("remindend")); } String tableName = request.getSession().getAttribute("tableName").toString(); if(tableName.equals("yuangong")) { wrapper.eq("yuangonggonghao", (String)request.getSession().getAttribute("username")); } int count = jixiaokaoheService.selectCount(wrapper); return R.ok().put("count", count); } }

六、论文参考

七、最新计算机毕设选题推荐

最新计算机软件毕业设计选题大全-CSDN博客

八、源码获取:

大家点赞、收藏、关注、评论啦 、👇🏻获取联系方式在文章末尾👇🏻

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/21 11:15:37

别再乱用BUFG了!Xilinx 7系列FPGA时钟架构实战避坑指南(从CC到CMT)

Xilinx 7系列FPGA时钟架构深度解析与工程实践指南 在高速数字系统设计中&#xff0c;时钟如同人体的血液循环系统&#xff0c;其质量直接决定了整个设计的成败。Xilinx 7系列FPGA提供了丰富而复杂的时钟资源架构&#xff0c;但许多工程师在使用过程中常常陷入"BUFG万能论…

作者头像 李华
网站建设 2026/5/21 11:15:01

VideoDownloadHelper:Chrome视频下载插件的完整使用指南

VideoDownloadHelper&#xff1a;Chrome视频下载插件的完整使用指南 【免费下载链接】VideoDownloadHelper Chrome Extension to Help Download Video for Some Video Sites. 项目地址: https://gitcode.com/gh_mirrors/vi/VideoDownloadHelper 在当今数字时代&#xff…

作者头像 李华
网站建设 2026/5/21 11:06:09

Mac安卓安全测试全链路:抓包、单向认证绕过与脱壳协同方案

1. 这不是“破解”&#xff0c;而是一次对安卓生态安全水位的实地测绘 你有没有遇到过这样的场景&#xff1a;手头有个内部测试用的安卓App&#xff0c;文档里写着“已启用双向TLS认证全量加固”&#xff0c;但开发同事临时请假&#xff0c;你又急需验证某个接口返回字段是否符…

作者头像 李华
网站建设 2026/5/21 11:06:08

Honey Select 2增强补丁:一键解锁完整汉化与300+插件功能

Honey Select 2增强补丁&#xff1a;一键解锁完整汉化与300插件功能 【免费下载链接】HS2-HF_Patch Automatically translate, uncensor and update HoneySelect2! 项目地址: https://gitcode.com/gh_mirrors/hs/HS2-HF_Patch HS2-HF_Patch是《Honey Select 2》游戏玩家…

作者头像 李华