当前位置: 首页 > news >正文

防破解暗桩思路:检查菜单是否被非法修改过源码

本篇文章属于《518抽奖软件开发日志》系列文章的一部分。

我在开发《518抽奖软件》(www.518cj.net)的时候,为了防止被破解,需用添加一些暗桩,在合适的时机检查软件是否被非法修改过,如果被非法修改就做出提示。可检查一些界面上的东西,比如菜单项是否被非法修改。

比如下述菜单项: 主菜单 > 设置 > 可靠性 (选正版)

搞破解的人,会把这个菜单项删除或去掉“选正版”几个字。检查这个是否被修改过,代码如下:

__forceinline bool check_menu()
{HMENU menu = LoadMenu(NULL, (LPCTSTR)IDRM_main);HMENU sub = GetSubMenu(menu, 0);WCHAR str[64] = { 0 };MENUITEMINFO mii = { 0 };mii.cbSize = sizeof(mii);mii.fMask = MIIM_TYPE;mii.cch = 64;mii.dwTypeData = str;GetMenuItemInfo(sub, IDM_safely, FALSE, &mii);WCHAR s[48] = { 0 }; // 可靠性...   (选正版)dec2wstr("F191F201F191F191F208F212F046F046F046F032F032F032F040F209F161F13F2536F230041", s);if (wcscmp(s, str) == 0) {DestroyMenu(menu); return TRUE;}DestroyMenu(menu); return FALSE;
}
  1. 这个检查是随机的,满足一定条件才触发,可提示用户不要用盗版,提示文字都是编码加密的。
  2. 这个检查函数是内联化的 __forceinline,这个函数里的文字也是编码加密过的,不容易被发现。
http://www.lryc.cn/news/148198.html

相关文章:

  • IDEA使用Docker插件
  • [前端] vue使用Mousetrap.js实现快捷键
  • 如何查询Oracle的字符集
  • C语言每日一练------------Day(7)
  • Meta语言模型LLaMA解读:模型的下载部署与运行代码
  • 人生中的孤独
  • 掌握Spring框架核心组件:深入探讨IOC、AOP、MVC及注解方式面试指南【经验分享】
  • 代码随想录算法训练营第37天 | ● 738.单调递增的数字 ● 968.监控二叉树 ● 总结
  • SOPC之NIOS Ⅱ实现电机转速PID控制(调用中断函数)
  • ElasticSearch安装为Win11服务
  • ransac拟合平面,代替open3d的segment_plane
  • Docker技术--Docker镜像管理
  • 生态环境保护3D数字展厅提供了一个线上环保知识学习平台
  • OPENCV实现计算描述子
  • Android View动画之LayoutAnimation的使用
  • 低代码与低代码平台的概念解析
  • 玩转Mysql系列 - 第8篇:详解排序和分页(order by limit),及存在的坑
  • Django实现音乐网站 ⒂
  • 爬虫逆向实战(二十八)--某税网第一步登录
  • 【Dots之003】SystemAPI.Query相关基础笔记
  • vue v-for 例子
  • 206.Flink(一):flink概述,flink集群搭建,flink中执行任务,单节点、yarn运行模式,三种部署模式的具体实现
  • 科技探究之旅--亲子研学活动
  • 华为云Stack的学习(三)
  • 大数据平台三大优势详解-行云管家
  • 智慧景区方案:AI与视频融合技术如何助力景区监管智能化升级?
  • HTML基础--Form表单--内联元素
  • 【月度刷题计划同款】常规状压 DP 启发式搜索
  • C#: Json序列化和反序列化,集合为什么多出来一些元素?
  • Docker教程-centos快速安装和配置Docker