百度翻译返回997错误,经过分析查询网络其他博客的示例,解决方法:如何计算sign
import requests
import execjs
import json
class MobileBaiduTranslate:
def __init__(self):
self.url = "https://fanyi.baidu.com/basetrans"
self.headers = {
"Cookie": "找到你自己的COOKIE",
"User-Agent": "找到你移动端的ua",
}
self.data = {
"from": "zh",
"to": "en",
"query": None,
"sign": None,
"token": "找到你自己的token"
}
def get_baidu_sign(self):
with open("baidusign.js") as f:
jsData = f.read()
sign = execjs.compile(jsData).call("a", self.input)
return sign
def run(self):
self.input = input("请输入要翻译的内容:")
self.get_baidu_sign()
self.data["query"] = self.input
self.data["sign"] = self.get_baidu_sign()
print(self.data)
response = requests.post(url=self.url, data=self.data, headers=self.headers)
#中文输出
# print(response.content.decode('unicode-escape'))
self.result_strs = response.content.decode()
def get_translate_result(self):
result_dict = json.loads(self.result_strs)
if 'trans' in result_dict:
result = result_dict['trans'][0]['dst'] if len( result_dict['trans']) > 0 else None
print("翻译结果为:")
print(result)
else:
print("请输入内容再进行翻译")
if __name__ == '__main__':
while True:
baidutranlate = BaiDuTranslateWeb()
baidutranlate.run()
baidutranlate.get_translate_result()
从公共库中找到签名方法
https://fanyi.baidu.com/static/translate-mobile/pkg/public_012ae1c.js
baidusign.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 a(r) {
var t = r.match(/[\uD800-\uDBFF][\uDC00-\uDFFF]/g);
if (null === t) {
var a = r.length;
a > 30 && (r = "" + r.substr(0, 10) + r.substr(Math.floor(a / 2) - 5, 10) + r.substr(-10, 10))
} else {
for (var C = r.split(/[\uD800-\uDBFF][\uDC00-\uDFFF]/), h = 0, f = C.length, u = []; f > h; h++) "" !== C[h] && u.push.apply(u, e(C[h].split(""))), h !== f - 1 && u.push(t[h]);
var g = u.length;
g > 30 && (r = u.slice(0, 10).join("") + u.slice(Math.floor(g / 2) - 5, Math.floor(g / 2) + 5).join("") + u.slice(-10).join(""))
}
var l = void 0, d = "" + String.fromCharCode(103) + String.fromCharCode(116) + String.fromCharCode(107);
l = null !== i ? i : (i = o.common[d] || "") || "";
for (var m = l.split("."), S = Number(m[0]) || 0, s = Number(m[1]) || 0, c = [], v = 0, F = 0; F < r.length; F++) {
var p = r.charCodeAt(F);
128 > p ? c[v++] = p : (2048 > p ? c[v++] = p >> 6 | 192 : (55296 === (64512 & p) && F + 1 < r.length && 56320 === (64512 & r.charCodeAt(F + 1)) ? (p = 65536 + ((1023 & p) << 10) + (1023 & r.charCodeAt(++F)), c[v++] = p >> 18 | 240, c[v++] = p >> 12 & 63 | 128) : c[v++] = p >> 12 | 224, c[v++] = p >> 6 & 63 | 128), c[v++] = 63 & p | 128)
}
for (var w = S, A = "" + String.fromCharCode(43) + String.fromCharCode(45) + String.fromCharCode(97) + ("" + String.fromCharCode(94) + String.fromCharCode(43) + String.fromCharCode(54)), b = "" + 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)), D = 0; D < c.length; D++) w += c[D], w = n(w, A);
return w = n(w, b), w ^= s, 0 > w && (w = (2147483647 & w) + 2147483648), w %= 1e6, w.toString() + "." + (w ^ S)
}