请求头参数加密分析思路

这篇博客探讨了如何使用JavaScript和Python对URL请求头中的参数进行加密。首先展示了JavaScript实现的missjson函数,该函数用于加密输入数据。然后,通过getResCode函数应用这个加密方法,结合当前时间戳生成加密的请求头参数。接着,博客提到了使用Python的base64库来达到类似的效果,将时间戳转换为加密字符串。这两种方法都成功地实现了数据的加密输出。
摘要由CSDN通过智能技术生成

请求头参数加密字样
在这里插入图片描述

通过url中关键字搜索定位到改函数
在这里插入图片描述
在这里插入图片描述
单步调试找到生成函数,并抠出函数
在这里插入图片描述

把抠出的js代码稍作改写
在这里插入图片描述
运行提示缺失missjson函数,继续补环境抠出missjson函数

在这里插入图片描述
在这里插入图片描述
运行继续报缺失missjson函数
在这里插入图片描述

再次执行js代码,正确输出
在这里插入图片描述
实现方式一:完整js代码如下

function missjson(input) {
    var keyStr = "ABCDEFGHIJKLMNOP" + "QRSTUVWXYZabcdef" + "ghijklmnopqrstuv" + "wxyz0123456789+/" + "=";
    var output = "";
    var chr1, chr2, chr3 = "";
    var enc1, enc2, enc3, enc4 = "";
    var i = 0;
    do {
        chr1 = input.charCodeAt(i++);
        chr2 = input.charCodeAt(i++);
        chr3 = input.charCodeAt(i++);
        enc1 = chr1 >> 2;
        enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
        enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
        enc4 = chr3 & 63;
        if (isNaN(chr2)) {
            enc3 = enc4 = 64;
        } else if (isNaN(chr3)) {
            enc4 = 64;
        }
        output = output + keyStr.charAt(enc1) + keyStr.charAt(enc2) + keyStr.charAt(enc3) + keyStr.charAt(enc4);
        chr1 = chr2 = chr3 = "";
        enc1 = enc2 = enc3 = enc4 = "";
    } while (i < input.length);

    return output;
}


function getResCode()  {
    var time = Math.floor(new Date().getTime() / 1000);
    return missjson("" + time);
}


console.log(getResCode())

实现方式二:用python实现

在这里插入图片描述

完整python代码:

# -*- coding: utf-8 -*-
import time
import base64
import math
time1 = math.floor(time.time() * 1000)
mcode = base64.b64encode(str(time1).encode()).decode()
print(mcode)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

生而为虫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值