百度翻译sign值的加密方法

第一步:打开百度翻译的链接https://fanyi.baidu.com/

输入要翻译的内容,发现结果是网页中直接显示的,所以可以断定网页是ajax加载的。C:\Users\admin\AppData\Roaming\Typora\typora-user-images\image-20200616140557426.png
第二步:打开开发者工具查看数据的请求方式

由于是ajax加载的,所以直接在network找到XHR的链接,找一下数据在哪个请求里面。
在这里插入图片描述

首先发现第一个请求https://fanyi.baidu.com/langdetect是post方式请求的,返回的内容是一串json,信息如上,可以断定为此请求是判断输入的语言是中文还是英文,中文返回lan:“zh”,英文返回lan:“en”。
在这里插入图片描述
第二个请求https://fanyi.baidu.com/v2transapi?from=en&to=zh也是post请求方式,携带参数有“from=en&to=zh&query=Python&transtype=realtime&simple_means_flag=3&sign=587387.791882&token=3f7b9ab5c1a408fbbaa65051fac0a32e&domain=common”,可以看出query是输入框输入要翻译的内容,在输入框输入其他内容后发现,有四个参数是变的,即要翻译的方式:from,to;要翻译的内容query,以及一个加密参数sign值。

接下来就js断点调试,找出这个sign值的加密方法。

第三步:js断点调试,找出sign值加密方法

上一步我们发现我们要的数据在包含https://fanyi.baidu.com/v2transapi的链接里,因此我们在Sources里把包含这个请求路径的链接加入断点中,然后选中。在这里插入图片描述

接下来网址输入https://fanyi.baidu.com/并请求

输入框输入Python,就会跳转到打断点的位置
在这里插入图片描述
代码会定位到上边的位置,就是这发出了上述链接的请求。继续一步步调试。
在这里插入图片描述

你会发现在https://fanyi-cdn.cdn.bcebos.com/static/translation/pkg/index_146703d.js这个js文件里有一个h变量里有想要的Sign值,接下来看上下文,找到sign: y(n),发现sign是y函数传入n参数生成的,此处n为输入的“Python”,找到y函数。在这里插入图片描述
看上文发现y函数就是7963行的e函数,r就是参数n
在这里插入图片描述

代码研究发现需要一个i变量和n函数,n函数在上边是有的,直接撸下来,接下来找这个i变量的值。

在7978行打断点调试后发现,i变量其实等于window[l],l=“gtk”,所以可以直接定义 var i = “320305.131321201”;就可以了。

抠下来的js代码如下:

var i = "320305.131321201";
function n(r, o) {
    for (var t = 0; t < o.length - 2; t += 3) {
        var a = o.charAt(t + 2);
        a = a >= "a" ? a.charCodeAt(0) - 87 : Number(a),
        a = "+" === o.charAt(t + 1) ? r >>> a : r << a,
        r = "+" === o.charAt(t) ? r + a & 4294967295 : r ^ a
    }
    return r
}
function e(r) {
    var o = r.match(/[\uD800-\uDBFF][\uDC00-\uDFFF]/g);
    if (null === o) {
        var t = r.length;
        t > 30 && (r = "" + r.substr(0, 10) + r.substr(Math.floor(t / 2) - 5, 10) + r.substr(-10, 10))
    } else {
        for (var e = r.split(/[\uD800-\uDBFF][\uDC00-\uDFFF]/), C = 0, h = e.length, f = []; h > C; C++)
            "" !== e[C] && f.push.apply(f, a(e[C].split(""))),
            C !== h - 1 && f.push(o[C]);
        var g = f.length;
        g > 30 && (r = f.slice(0, 10).join("") + f.slice(Math.floor(g / 2) - 5, Math.floor(g / 2) + 5).join("") + f.slice(-10).join(""))
    }
    var u = void 0
      , l = "" + String.fromCharCode(103) + String.fromCharCode(116) + String.fromCharCode(107);
    u = null !== i ? i : (i = window[l] || "") || "";
    for (var d = u.split("."), m = Number(d[0]) || 0, s = Number(d[1]) || 0, S = [], c = 0, v = 0; v < r.length; v++) {
        var A = r.charCodeAt(v);
        128 > A ? S[c++] = A : (2048 > A ? S[c++] = A >> 6 | 192 : (55296 === (64512 & A) && v + 1 < r.length && 56320 === (64512 & r.charCodeAt(v + 1)) ? (A = 65536 + ((1023 & A) << 10) + (1023 & r.charCodeAt(++v)),
        S[c++] = A >> 18 | 240,
        S[c++] = A >> 12 & 63 | 128) : S[c++] = A >> 12 | 224,
        S[c++] = A >> 6 & 63 | 128),
        S[c++] = 63 & A | 128)
    }
    for (var p = m, F = "" + String.fromCharCode(43) + String.fromCharCode(45) + String.fromCharCode(97) + ("" + String.fromCharCode(94) + String.fromCharCode(43) + String.fromCharCode(54)), D = "" + String.fromCharCode(43) + String.fromCharCode(45) + String.fromCharCode(51) + ("" + String.fromCharCode(94) + String.fromCharCode(43) + String.fromCharCode(98)) + ("" + String.fromCharCode(43) + String.fromCharCode(45) + String.fromCharCode(102)), b = 0; b < S.length; b++)
        p += S[b],
        p = n(p, F);
    return p = n(p, D),
    p ^= s,
    0 > p && (p = (2147483647 & p) + 2147483648),
    p %= 1e6,
    p.toString() + "." + (p ^ m)
}

Python执行js用execjs就可以了。

    with open("baidufanyi.js", "r") as fp:
        js_data = fp.read()
    sign = execjs.compile(js_data).call("e", keyword)
    print(sign)
  • 10
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值