一.原理

安卓开发调用md5加密时候都会调用到系统类java.security.MessageDigest

加密时候会会调用里面2个关键方法update以及digest

根据这个原理我们开始写代码吧

二.代码

hook.js

function Uint8ArrayToString(fileData){    //Uint8Array转字符串
var dataString = "";
for (var i = 0; i < fileData.length; i++) {
dataString += String.fromCharCode(fileData[i]);
// console.log(dataString)
}
return dataString
}
function byteToHexString(uint8arr) { //byte数组转16进制字符串
if (!uint8arr) {
return '';
}
var hexStr = '';
for (var i = 0; i < uint8arr.length; i++) {
var hex = (uint8arr[i] & 0xff).toString(16);
hex = (hex.length === 1) ? '0' + hex : hex;
hexStr += hex;
} return hexStr.toUpperCase();
}
Java.perform(function () {
var BB = Java.use("java.security.MessageDigest");
BB.update.overload('[B').implementation = function (args1, args2, args3, args4, args5, args6) {
console.log(Uint8ArrayToString(args1))
var args = this.update(args1)
console.log("update", args)
return args
}
BB.digest.overload().implementation = function (args1, args2, args3, args4, args5, args6) {
var args = this.digest()
console.log(byteToHexString(args))
return args
}
});

可以直接cmd窗口调用(老手推荐)

frida -U 包名 -l js
#修改js他会热更新

可以用python调用(新手推荐)

import logging
import frida
import sys def on_message(message, data):
if message['type'] == 'send':
print("[*] {0}".format(message['payload']))
else:
print(message) with open('hook.js', 'r', encoding='utf-8') as f: # js文件
sta = ''.join(f.readlines()) rdev = frida.get_remote_device() session = rdev.attach("xxxxxx") #app包名
print(session)
script = session.create_script(sta)
print(script)
def show(message,data):
print(message)
script.on("message",show) # 加载脚本
script.load()
sys.stdin.read()

三.显示效果

为什么博客园要限制字数,简单明确的说明方法他不香吗,一定要来一堆废话

为什么博客园要限制字数,简单明确的说明方法他不香吗,一定要来一堆废话

为什么博客园要限制字数,简单明确的说明方法他不香吗,一定要来一堆废话

为什么博客园要限制字数,简单明确的说明方法他不香吗,一定要来一堆废话

为什么博客园要限制字数,简单明确的说明方法他不香吗,一定要来一堆废话

为什么博客园要限制字数,简单明确的说明方法他不香吗,一定要来一堆废话

为什么博客园要限制字数,简单明确的说明方法他不香吗,一定要来一堆废话

为什么博客园要限制字数,简单明确的说明方法他不香吗,一定要来一堆废话

为什么博客园要限制字数,简单明确的说明方法他不香吗,一定要来一堆废话

为什么博客园要限制字数,简单明确的说明方法他不香吗,一定要来一堆废话

为什么博客园要限制字数,简单明确的说明方法他不香吗,一定要来一堆废话

为什么博客园要限制字数,简单明确的说明方法他不香吗,一定要来一堆废话

为什么博客园要限制字数,简单明确的说明方法他不香吗,一定要来一堆废话

为什么博客园要限制字数,简单明确的说明方法他不香吗,一定要来一堆废话

为什么博客园要限制字数,简单明确的说明方法他不香吗,一定要来一堆废话

最新文章

  1. Servlet和JSP学习指导与实践(一):Servlet API初探
  2. 1-MySQL命令行
  3. [OpenJudge 3064]坠落的蚂蚁
  4. ThinkPHP控制器
  5. floor舍去法取整
  6. 在jsp中的css
  7. Quartz1.8.5例子(六)
  8. T4模板之菜菜鸟篇
  9. Vim配置及使用笔记
  10. C#多条件查出来的多个DataSet,然后循环将数据整合
  11. Linux自动化命令工具expect
  12. sface
  13. 连接mysql用mysql_connect不能连接
  14. tf.expand_dims 来增加维度
  15. elasticsearch5.6.3插件部署
  16. Linux下修改MySql的root密码
  17. JAVA正则表达式-捕获组与非捕获组
  18. Java项目中classpath路径
  19. Kafka集群无法外网访问问题解决攻略
  20. 小程序切换账户拉取仓库文件的appid提示

热门文章

  1. Python中高级知识(非专题部分)学习随笔
  2. [MRCTF2020]Ezpop
  3. 【软件测试部署基础】gradle的认识
  4. john快速破解各种散列hash
  5. k8s 节点 notReady问题解决流程
  6. element ui中循环出来的表格勾选问题
  7. caffe源码 理解链式法则
  8. 海量数据架构下如何保证Mycat的高可用?
  9. C# 高性能对象映射
  10. Java-静态关键字Static&amp;静态代码块