Ja-netfilter(idea激活码破解原理)分析

news2025/1/11 8:03:11

Ja-netfilter(idea破解)分析

简介

  • ja-netfilter是一款可以破解jetbrainsIDE系列的javaagent jar 包。

原理简介

  • 通过javaagent创造修改字节码的时机。
  • 通过asm修改相关类,达到hook特定方法的作用。
  • 主要依赖power(rsa方法hook),url(拦截网络验证码校验),dns(拦截特定域名请求)插件。

原理分析

首先先简单了解下整理流程,后面详细讲解每个步骤。

正常启动idea流程

  1. 点击idea快捷方式,或者idea.bat / idea.sh启动。

  2. 根据环境变量加载对应vm参数。也就是vmoptions文件,vm中的内容会作为jvm启动参数添加到启动命令中。

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

  3. 本地校验激活码

  4. rpc接口校验激活码

在这里插入图片描述

使用ja-netfilter流程

  1. 运行install脚本(通过环境变量指定启动vm参数文件地址),也就是jar包目录下的vmoptions目录。
  2. 启动idea。
  3. 加载ja-netfilter vm参数(在ja-netfilter的vm参数中添加了asm支持以及javaagent参数,并指定当前jar包)。
  4. 运行javaagent,及ja-netfilter.jar 的permain方法。
    1. 加载ja-netfilter定义的插件,也即plugins目录下的jar包。
    2. 初始化插件,载入配置,也即config目录下的jar包。
    3. 通过javaagent提供的类转换能力转换插件hook的类。
  5. 本地校验激活码
  6. 网络rpc校验激活码

在这里插入图片描述

ja-netfilter代码分析

  • 我这里直接调试idea,通过idea.bat启动。启动后在通过agent技术嵌入到idea目录虚拟机中,已达到调试idea的目录。
  • com.janetfilter.core.Launcher是主启动类,定义了permain已经agentmain方法。同时在manifest指定了Premain-Class。
  1. 使用idea.bat启动idea

在这里插入图片描述

  1. 使用javaagent嵌入到目标虚拟机。

    在这里插入图片描述

  2. 进入javaagner(ja-netfiler)定义的permain方法,开始执行ja-netfiler逻辑。

    在这里插入图片描述

  3. 确定插件目录以及配置目录

    在这里插入图片描述

  4. 加载插件,加载配置并初始化

    在这里插入图片描述

    在这里插入图片描述

在这里插入图片描述

ja-netfiler插件介绍

  • ja-netfiler的插件结构大致可以分为三类
    • 插件入口类(例如:DNSFilterPlugin),用来注册对应的类转换器。
    • Transformer类(例如:InetAddressTransformer),用来定义需要hook的类名,以及hook方法的逻辑。
    • 过滤器业务逻辑类(例如:DNSFilter),类转换之后被hook会真正调用到的类,一般用于拦截或者替换。
dns插件
  • DNSFilterPlugin

    • 初始化转换类并注册

      在这里插入图片描述

  • InetAddressTransformer

    • hook了java/net/InetAddress类的getAllByName方法以及isReachable方法。

      在这里插入图片描述

    • 修改之后的InetAddress代码大致如下:

      public class InetAddress {
      
          public static InetAddress[] getAllByName(String hostName) throws UnknownHostException {
              return DNSFilter.testQuery(hostName) == null ? new InetAddress[0] : super.getAllByName(hostName);
          }
      
          public boolean isReachable(NetworkInterface netif, int timeout, int ttl) throws SocketException {
              InetAddress reachableAddress = DNSFilter.testReachable(this);
              if (reachableAddress != null) {
                  return true;
              } else {
                  return false;
              }
          	// ...    
          }
      }
      
  • DNSFilter

    在这里插入图片描述

总结
  • dns插件hook了InetAddress类的getAllByName方法,如何匹配配置的域名,则抛出UnknownHostException异常。以及isReachable方法,如何匹配规则则返回false。

  • dns对应配置

    [DNS]
    EQUAL,jetbrains.com
    EQUAL,plugin.obroom.com
    
  • 也就是访问jetbrains.com以及plugin.obroom.com都是失败的。

power插件
总结
  • power插件hook了BigIntegeroddModPow方法,这个方法是用来对一个数模取幂运算的,及x.oddModPow(y,z) = x^y % z。RSA非对称加密底层会使用到当前方法。

  • 可以简单理解为在oddModPow函数前加了一段逻辑,就是如果入参x,y,z匹配配置的规则,那么就返回规则配置的结果。

    public class BigInteger {
        public static BigInteger oddModPow(BigInteger x, BigInteger y, BigInteger mod) {
            BigInteger result = ResultFilter.testFilter(x, y, mod);
            if (result != null) {
                return result;
            }
            // ...
        }
    }
    
url插件
总结
  • url插件hook了HttpClientopenServer方法。在执行逻辑之前调用testUrl方法。

    public class HttpClient {
        public void openServer() {
            URLFilter.testURL(url);
            // ...
        }
    }
    
  • testUrl方法中的逻辑为如果匹配了规则中设置的url,那么就抛出SocketTimeoutException异常,也即不能访问指定url。

    public static URL testURL(URL url) throws IOException {
        if (null == url || null == ruleList) {
            return null;
        }
    
        for (FilterRule rule : ruleList) {
            if (!rule.test(url.toString())) {
                continue;
            }
    
            DebugInfo.output("Reject url: " + url + ", rule: " + rule);
            throw new SocketTimeoutException("connect timed out");
        }
    
        return url;
    }
    
  • 对应规则为

    [URL]
    PREFIX,https://account.jetbrains.com/lservice/rpc/validateKey.action
    
  • 那么这里就是只要前缀匹配了当前地址,也即是rpc校验激活码的地址,那么就会抛出异常,自然也就无法网络校验了。

Idea调试
  • 可以看到,在输入验证码之后,会调用RAS相关方法来校验激活码,这里就会调用到ja-netfiler插件power的方法。如果匹配了对应的配置,就会给出一个结果来替换oddModPow的结果。

    在这里插入图片描述

  • 校验验证码成功,激活成功

    在这里插入图片描述

  • 点击继续,关闭弹窗,idea会调用rpc接口校验验证码,url插件匹配规则,抛出异常。

    在这里插入图片描述

参考

https://zhuanlan.zhihu.com/p/494706735

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1591152.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Java】Set集合的基本使用

📝个人主页:哈__ 期待您的关注 一、HashSet集合 1.HashSet集合的特点 2.HashSet常用方法 ①:add(Object o):向Set集合中添加元素,不允许添加重复数据。 ②:size():返回Set集合中的元素个数…

NASA数据集——亚洲夏季季风化学与气候影响项目超高灵敏度气溶胶光谱(UHSAS)数据

ACCLIP_Aerosol_AircraftInSitu_WB57_Data 简介 ACCLIP_Aerosol_AircraftInSitu_WB57_Data 是亚洲夏季季风化学与气候影响项目(ACCLIP)期间收集的原地气溶胶数据。本数据集收录了来自下一代激光质谱仪(PALMS-NG)、单颗粒烟尘光度…

0101tomcat部署war访问mysql失败-容器间通信-docker项目部署

文章目录 一、简介二、部署1、mysql数据迁移2、docker部署redis3、docker部署tomcat并运行war包 三、报错四、解决1 分析2 解决 结语 一、简介 最近参与开发一个项目,其中一部分系统需要迁移。从阿里云迁移到实体服务器,使用docker部署。系统使用Java语…

RAG进阶之通用文档处理:从RAGFlow、TextMonkey到mPLUG-DocOwl 1.5

前言 我司RAG项目组每个月都会接到一些B端客户的项目需求,做的多了,会发现很多需求是大同小异的,所以我们准备做一个通用的产品,特别是对通用文档的处理 而在此之前,我们则想先学习一下目前市面上各种优秀的解决方法…

IIS服务器更换即将过期的SSL证书

公司IIS服务器证书快要过期,替换证书的步骤: Winr输入mstsc命令,显示远程登录;输入服务器IP以及密码,进行远程登陆登陆IIS服务器,winr输入inetmgr命令显示IIS操控器;选择服务器证书--点击服务器…

成为摄影拍照高手,摄影技术进阶秘籍

一、资料前言 本套摄影高手资料,大小2.02G,共有57个文件。 二、资料目录 DSLR数码单反摄影圣经.pdf photoshop超细的人像后期磨皮及专业美化.docx “失传”的人像拍摄绝技.doc 白加黑减.怎样应用曝光补偿.pdf 标准镜头秘笈:标准镜如何…

快速寻找可以构建出网通信隧道的计算机

点击星标,即时接收最新推文 本文选自《内网安全攻防:红队之路》 扫描二维码五折购书 为加强内网的安全防范,安全管理员往往会限制内网计算机访问互联网,当然不同机构的限制策略是不一样的,有的完全阻断了内网计算机访问…

langchain LCEL,prompt模块,outputparse输出模块

目录 基本代码 prompt模块 prompt模版控制长度 outputparse格式化输出 并行使用调用链 LangChain表达式语言,或者LCEL,是一种声明式的方式,可以轻松地将链条组合在一起 langchian 可以使用 通义千问,我们用通义千问&#x…

openkylin系统通过网线连接ubuntukylin系统上网攻略

openkylin系统通过网线连接ubuntukylin系统上网攻略 主机1:x64 amd ,系统:ubuntukylin 22.04 ,状态:通过wifi连接热点进行上网,并共享网络。 主机2:x64 intel ,系统:ope…

阿里一面:如何将重复性比较高的 String 类型的地址信息从 20GB 降到几百兆?...

这次应该是互联网及软件行业的第三次寒潮,大家在寒潮中一定要继续保持学习,寒潮挺过去以后还是会迎来新的发展机遇。 有粉丝去阿里面试,跟码哥分享了其中一题面试问题「如何将重复性比较高的 String 类型的地址信息从 20GB 降到几百兆&#x…

linux创建文件、linux创建文件的几种方式、touch、echo、cat、vi、vim

文章目录 一、创建文件1.1、touch1.2、echo1.3、cat1.4、vi或vim 一、创建文件 1.1、touch touch命令:用于创建一个新的空文件或者更新已存在文件的访问和修改时间。 (1)如果目标文件不存在,则新建一个文件 touch demo.txt&am…

AcWing 1388. 游戏(每日一题)

原题链接:1388. 游戏 - AcWing题库 玩家一和玩家二共同玩一个小游戏。 给定一个包含 N 个正整数的序列。 由玩家一开始,双方交替行动。 每次行动可以在数列的两端之中任选一个数字将其取走,并给自己增加相应数字的分数。(双方…

Vscode设置滚轮进行字体大小的调节

Vscode设置滚轮进行字体大小的调节 正常的话按 ctrl 或者 ctrl - 进行字体的大小调节 1.打开Vscode,找打设置的图标,在点击设置,或者直接使用快捷键,【ctrl ,】 2. 在搜索框搜索Font Ligatures 3.双击进入settings.json ,找到如…

[大模型]# Yi-6B-Chat Lora 微调

Yi-6B-Chat Lora 微调 概述 本节我们介绍如何基于 transformers、peft 等框架,对 Yi-6B-Chat 模型进行 Lora 微调。Lora 是一种高效微调方法,深入了解其原理可参见博客:知乎|深入浅出Lora。 本节所讲述的代码脚本在同级目录 04-Yi-6B-Chat…

【教学类-52-04】20240412动物数独(4宫格)空1-空15

作品展示 背景需求: 【教学类-52-03】20240412动物数独(4宫格)难度1-9 打印版-CSDN博客文章浏览阅读603次,点赞20次,收藏8次。【教学类-52-03】20240412动物数独(4宫格)难度1-9 打印版https://…

Razzashi Raptor

拉扎什迅猛龙 Razzashi Raptor 95000金(游戏币)比老虎便宜多了,捡漏啊 为啥我开团都不出,很生气,去打架!!

【题目】【信息安全管理与评估】2022年国赛高职组“信息安全管理与评估”赛项样题2

【题目】【信息安全管理与评估】2022年国赛高职组“信息安全管理与评估”赛项样题2 信息安全管理与评估 网络系统管理 网络搭建与应用 云计算 软件测试 移动应用开发 任务书,赛题,解析等资料,知识点培训服务 添加博主wx:liuliu548…

在线药房数据惨遭Ransomhub窃取,亚信安全发布《勒索家族和勒索事件监控报告》

本周态势快速感知 本周全球共监测到勒索事件119起,与上周相比勒索事件有所增长。 本周Blacksuit是影响最严重的勒索家族,Ransomhub和Blackbasta恶意家族紧随其后,从整体上看Lockbit3.0依旧是影响最严重的勒索家族,需要注意防范。…

《五》QListWidget列表框

QListWidgetQListWidget和QListWidgetItem QListWidget 是qt中的列表框控件,它用于显示多个列表项,列表项对应的类是QListWidgetItem. QListWidget列表框的创建 QListWidget 类的继承关系如下: QListWidget -> QListView -> QAbs…

SonarQube 9.9.4 LTS社区版安装

目标 安装个SonarQube社区版. 安装SonarQube9.9.4 LTS社区版 https://binaries.sonarsource.com/Distribution/sonarqube/sonarqube-9.9.4.87374.zip # 切换到安装目录 cd /opt # 下载安装包 sudo wget https://binaries.sonarsource.com/Distribution/sonarqube/sonarqube…