猿人学app安卓比赛第一题sign参数

2024-01-15 13:10

本文主要是介绍猿人学app安卓比赛第一题sign参数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、抓包

1.这里使用的是charles,配置charles抓包

可以看到有三个参数:page、t、sign

2.猜想:sign是不是page和t某种组合方式之后的加密

3.加密方式:

  • HmacMD5
  • MD5 32位
  • UUID

4.那么我们还原sign参数之后,去构建请求1-100页返回的数据只和即可过关

二、分析

1.使用jadx打开猿人学app,将apk拖到jadx即可,可以看到是混淆之后的,但是不要怕

2。根据接口的url,我们搜索 /app1,之后转到这个地方

转到之后是这样的,一看有page、有sign、有t,那就是这里了

然后进到OooO00o里

随便进一个

之后搜索sign,定位到了这

跳到这个sign的声明,右键sign-跳到声明,这里就是我们要找的地方

三、frida hook

找到sign的生成就要开始hook了,这里参考了猿人学-APP大赛-第一题-Frida初试、调用Java代码_猿人学app第一题_银古_1427的博客-CSDN博客

1.分析,参数主要是 sb 转 string 再转 bytes 传入的

2.启动frida,hook这个sign

import frida
import sysdef bytes2str(ascii_lst):'''bytes 列表转字符串'''string = ''.join(map(chr, ascii_lst))print(string)def on_message(message, data):if message["type"] == "send":print(f"send >>> {message['payload']}")bytes2str(message['payload'])else:print(f"log >>> {message}")test = '''
function main(){console.log("脚本加载成功");Java.perform(function() {var clazz = Java.use('com.yuanrenxue.match2022.security.Sign');clazz.sign.implementation = function() {console.log('进入函数内部');console.log("参数为:", arguments[0]);send(arguments[0]);console.log("结果为:",clazz.sign.apply(this, arguments));return clazz.sign.apply(this, arguments);}});
}
setImmediate(main)
'''
# 两种启动方式
# 第一种 启动方式(app已经启动起来)
process = frida.get_usb_device(-1).attach('猿人学2022')  # 手机启动的进程名字(包名)
script = process.create_script(test)  # js hook代码放进去
script.on('message', on_message)  # 开始hook操作
script.load()
sys.stdin.read()  # 一直挂在这里,python程序不要断掉# 第二种 spawn重启app,可以hook app启动阶段加载流程的application,正在加载阶段的一些,frida版本与手机不匹配可能会闪崩
# device = frida.get_usb_device(-1)
# # 通过spawn方式活得进程id,然后去重启这个app
# pid = device.spawn(['com.yuanrenxue.match2022.security'])  # 手机启动的进程名字(包名)
# process = device.attach(pid)
  • 一直没有输出的话,先退出重新启动app,再运行脚本
  • 一直进入不了函数内部的话,可以使用 rpc 的方式
  • 不需要 on_message 也可以打印

这里的hook结果是这样的:

四、编写脚本

这里用的是Frida rpc,参考:猿人学-APP大赛-第一题-Frida初试、调用Java代码_猿人学app第一题_银古_1427的博客-CSDN博客,主要就是把sign函数暴漏出来

# -*- coding:utf-8 -*-
import frida, time, sys
import requests# from requests.packages import urllib3
def on_message(message, data):if message['type'] == 'send':print("[*] {0}".format(message['payload']))else:print(message)def get_url():device = frida.get_usb_device(timeout=1000)  # 获取USB设备句柄process = device.attach('猿人学2022')  # 注入进程print(process)with open('第一题.js', encoding='utf-8') as f:jscode = f.read()script = process.create_script(jscode)  # 加载js代码script.on('message', on_message)  # 监控任何来自目标进程的消息script.load()print('load js ok')num = 0for i in range(1, 101):url = 'https://appmatch.yuanrenxue.com/app1'headers = {'Host': 'appmatch.yuanrenxue.cn','accept-language': 'zh-CN,zh;q=0.8','user-agent': 'Mozilla/5.0 (Linux; U; Android 7.1.1; zh-cn; ONEPLUS A3010 Build/NMF26F) AppleWebKit/534.30 (KHTML, like Gecko) Version/4.0 Mobile Safari/534.30','content-type': 'application/x-www-form-urlencoded','cache-control': 'no-cache',}data = {'page': str(i),'t': str(int(time.time())),'token': '你自己的token',}data['sign'] = script.exports.main('page=' + data['page'] + data['t'])print(data)response = requests.post(url, headers=headers, data=data, verify=False)print(response.json())value_data = response.json()for value in value_data['data']:num += int(value['value'])print(num)time.sleep(1)if __name__ == '__main__':get_url()

第一题.js的代码:

//字符串转字节序列
function stringToByte(str) {var bytes = new Array();var len, c;if (str) {len = str.length;for (var i = 0; i < len; i++) {c = str.charCodeAt(i);if (c >= 0x010000 && c <= 0x10FFFF) {bytes.push(((c >> 18) & 0x07) | 0xF0);bytes.push(((c >> 12) & 0x3F) | 0x80);bytes.push(((c >> 6) & 0x3F) | 0x80);bytes.push((c & 0x3F) | 0x80);} else if (c >= 0x000800 && c <= 0x00FFFF) {bytes.push(((c >> 12) & 0x0F) | 0xE0);bytes.push(((c >> 6) & 0x3F) | 0x80);bytes.push((c & 0x3F) | 0x80);} else if (c >= 0x000080 && c <= 0x0007FF) {bytes.push(((c >> 6) & 0x1F) | 0xC0);bytes.push((c & 0x3F) | 0x80);} else {bytes.push(c & 0xFF);}}}return bytes;
}//主动调用sign函数
var a
var yyfunction main(a) {console.log("Script loded successfully")console.log(a)Java.perform(function () {console.log("Inside java perform function")var Sign = Java.use('com.yuanrenxue.match2022.security.Sign')//对指定的类名动态的获取这个类的JavaScript引用console.log("Java.use.successfully") //定位类var asinn = Sign.$new()   //创建实例yy = asinn.sign(stringToByte(a))console.log(yy) //定位类})return yy
}//入口函数
rpc.exports = {main: main
}

五、成果(开心~)

参考文章:猿人学逆向比赛第一题sign参数(第三期)_wx63da3ca9e1323的技术博客_51CTO博客、猿人学-APP大赛-第一题-Frida初试、调用Java代码_猿人学app第一题_银古_1427的博客-CSDN博客

这篇关于猿人学app安卓比赛第一题sign参数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/weixin_44851624/article/details/130368321
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/609009

相关文章

一文详解PostgreSQL复制参数

《一文详解PostgreSQL复制参数》PostgreSQL作为一款功能强大的开源关系型数据库,其复制功能对于构建高可用性系统至关重要,本文给大家详细介绍了PostgreSQL的复制参数,需要的朋友可... 目录一、复制参数基础概念二、核心复制参数深度解析1. max_wal_seChina编程nders:WAL

Linux高并发场景下的网络参数调优实战指南

《Linux高并发场景下的网络参数调优实战指南》在高并发网络服务场景中,Linux内核的默认网络参数往往无法满足需求,导致性能瓶颈、连接超时甚至服务崩溃,本文基于真实案例分析,从参数解读、问题诊断到优... 目录一、问题背景:当并发连接遇上性能瓶颈1.1 案例环境1.2 初始参数分析二、深度诊断:连接状态与

史上最全nginx详细参数配置

《史上最全nginx详细参数配置》Nginx是一个轻量级高性能的HTTP和反向代理服务器,同时也是一个通用代理服务器(TCP/UDP/IMAP/POP3/SMTP),最初由俄罗斯人IgorSyso... 目录基本命令默认配置搭建站点根据文件类型设置过期时间禁止文件缓存防盗链静态文件压缩指定定错误页面跨域问题

SpringBoot请求参数接收控制指南分享

《SpringBoot请求参数接收控制指南分享》:本文主要介绍SpringBoot请求参数接收控制指南,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring Boot 请求参数接收控制指南1. 概述2. 有注解时参数接收方式对比3. 无注解时接收参数默认位置

Python使用getopt处理命令行参数示例解析(最佳实践)

《Python使用getopt处理命令行参数示例解析(最佳实践)》getopt模块是Python标准库中一个简单但强大的命令行参数处理工具,它特别适合那些需要快速实现基本命令行参数解析的场景,或者需要... 目录为什么需要处理命令行参数?getopt模块基础实际应用示例与其他参数处理方式的比较常见问http

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

如何解决idea的Module:‘:app‘platform‘android-32‘not found.问题

《如何解决idea的Module:‘:app‘platform‘android-32‘notfound.问题》:本文主要介绍如何解决idea的Module:‘:app‘platform‘andr... 目录idea的Module:‘:app‘pwww.chinasem.cnlatform‘android-32

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

Spring Boot项目部署命令java -jar的各种参数及作用详解

《SpringBoot项目部署命令java-jar的各种参数及作用详解》:本文主要介绍SpringBoot项目部署命令java-jar的各种参数及作用的相关资料,包括设置内存大小、垃圾回收... 目录前言一、基础命令结构二、常见的 Java 命令参数1. 设置内存大小2. 配置垃圾回收器3. 配置线程栈大小