免费翻译API破解(简易翻译工具)
思路:选取有道翻译,用fiddler抓取接口请求信息,提取相关请求参数,破解加密部分。

主要请求数据:
i :翻译文本
ts:时间戳
salt:ts +随机数
sign:加密信息,经过抓取信息,发现sign = md5(固定字符串1+ i + salt +固定字符串2) 固定字符串请百度方法。
数据经过urlencode后请求,获取到json数据后取出翻译文本。
下面直接上代码:
#coding = utf-8
import requests
from urllib import parse
from hashlib import md5
import hashlib
import time,random class YouDaofanyi(object): def __init__(self,text): self.url = "http://fanyi.youdao.com/translate_o?smartresult=dict&smartresult=rule"
self.method = "POST"
self.headers = {
"Origin": "http://fanyi.youdao.com",
"Referer": "http://fanyi.youdao.com/",
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/64.0.3282.140 Safari/537.36 Edge/17.17134",
"Content-Type": "application/x-www-form-urlencoded; charset=UTF-8",
"Accept": "application/json; text/javascript; */*; q=0.01",
"X-Requested-With": "XMLHttpRequest",
"Accept-Language": "zh-CN",
"Accept-Encoding": "gzip; deflate",
"Connection": "Keep-Alive",
"host" : "fanyi.youdao.com",
"Cookie": "xxxxxxxx"
} self.text = text
utc = int(time.time() * 1000)
salt = utc*10 + random.randint(0,11) #print(utc,salt)
signstr = ("fanyideskweb" + str(text) + str(salt) +"rY0D^0'nM0}g5Mm1z%1G4").encode("utf-8")
md5 = hashlib.md5()
md5.update(signstr)
sign = md5.hexdigest() print("input text is : %s" % text)
post_data ={"i":text,
"smartresult":"dict",
"from":"AUTO",
"to":"AUTO",
"client":"fanyideskweb",
"salt":salt,
"sign":sign,
"ts":str(utc),
"bv":"435192ea8debc53c68e5c13d953099ff",
"doctype":"json",
"version":2.1,
"keyfrom":"fanyi.web",
"action":"FY_BY_REALTIME",
"typoResult":"false"
}
self.data = parse.urlencode(post_data) def translate(self):
test = requests.post(url = self.url,data= self.data,headers =self.headers)
resultjson = test.json() if resultjson == {'errorCode': 50}:
translate = ""
else:
try:
translate = resultjson["translateResult"]
translate = translate[0][0]["tgt"]
print("translate result is : %s" % translate)
except KeyError as f:
translate ="" return translate
后面想到做一个小工具能翻译文本内容,又能翻译excel档文件,马上实现了,这里把翻译文本直接追加到对应的单元格。
#coding=utf-8 import xlrd,xlwt
from xlrd import *
import Translate
from xlutils.copy import copy def TypeCheck(typename):
flag = False
if typename == 0:
print("单元格内容为空")
elif typename ==1:
print("字符串,翻译中...")
flag = True
elif typename == 2:
print("单元格为数字")
elif typename ==3:
print ("单元格为日期")
elif typename == 4:
print("单元格为布尔类型")
else:
print("格式获取错误")
return flag def Excelread(filename):
rd = xlrd.open_workbook(filename)
sheet = rd.sheet_by_index(0)
readtext = []
readalltext =[]
for i in range(1000):
for j in range(1000):
try:
valuetype = sheet.cell(i,j).ctype
resulttype = TypeCheck(valuetype)
if resulttype== False:
print("不需要进行翻译的内容")
else:
value = sheet.cell_value(i, j)
translatevalue = Translate.translate(value)
newvalue = str(value) + translatevalue
ExcelWrite(filename,i,j,newvalue)
readtext.append(value)
except IndexError as f:
pass
readalltext.append(readtext)
readtext = []
flag = False
for i in range(len(readalltext)):
if readalltext[i] != []:
flag = True
break
else:
pass
return flag def ExcelWrite(filename,raw,cow,value):
rb = xlrd.open_workbook(filename)
wt = copy(rb)
s = wt.get_sheet(0)
s.write(raw,cow,value)
wt.save(filename)
再加上tk部分代码:
try:
root = Tkinter.Tk()
root.title("翻译工具")
root.geometry("850x350") root.resizable(width=False, height=False)
Tkinter.Label(root, text='有道翻译区域', fg='blue', font=("黑体", 20, "bold")).grid(row=0, column=2)
Tkinter.Label(root, text='*Version: v0.1-20190329*', fg='blue', font=("黑体", 10)).grid(row=11, column=4)
Tkinter.Label(root, text='*Design : Sandy1128*', fg='blue', font=("黑体", 10)).grid(row=12, column=4) Tkinter.Label(root,text='需要翻译的文本:',font=("黑体", 10)).grid(row=1,column=1)
fanyitext_t=Tkinter.Text(root,height=5,width=60, fg='blue')
fanyitext_t.grid(row=1,column=2)
fanyitext_t.insert('0.0','123') Tkinter.Label(root, text='或需要翻译的文件路径:',font=("黑体", 10)).grid(row=2, column=1)
fanyifname_t = Tkinter.Text(root, height=5, width=60, fg='blue')
fanyifname_t.grid(row=2, column=2) fanyiinputfile =Tkinter.Button(root, text='浏览',activeforeground = "red",fg='blue',font=("黑体", 12, "bold"), height =2,command= selectfilefanyi)
fanyiinputfile.grid(row = 2,column = 3) btn_fanyi=Tkinter.Button(root,text='开始翻译',activeforeground = "red",fg='black',font=("黑体", 12, "bold"),height = 2,command=qidongfanyiapp)
btn_fanyi.grid(row=5,column=3) root.mainloop() except Exception as e:
pass
视图:

可以将python代码打包成exe文件,方便使用。
免费翻译API破解(简易翻译工具)的更多相关文章
- 基于百度通用翻译API的一个翻译小工具
前几天写了一个简单的翻译小工具,是基于有道翻译的,不过那个翻译接口有访问限制,超过一定次数后会提示访问过于频繁,偶然发现百度翻译API如果月翻译字符少于200万是不收取费用的,所以就注册了一个百度开发 ...
- C++中使用Curl和JsonCpp调用有道翻译API实现在线翻译
使用C++开发一个在线翻译工具,这个想法在我大脑中过了好几遍了,所以就搜了下资料,得知网络上有很多翻译API,这里我选择我平时使用较多的有道翻译API进行在线翻译工具开发的练习.翻译API返回的结果常 ...
- 利用百度翻译API,获取翻译结果
利用百度翻译API,获取翻译结果 translate.py #!/usr/bin/python #-*- coding:utf-8 -*- import sys reload(sys) sys.set ...
- 利用有道翻译Api实现英文翻译功能
有道翻译提供了翻译和查词的数据接口.通过数据接口,您可以获得一段文本的翻译结果或者查词结果. 通过调用有道翻译API数据接口,您可以在您的网站或应用中更灵活地定制翻译和查词功能. 第一步: ...
- C++调用有道翻译API实现在线翻译之发声篇
大概半月前写了一篇博文:C++中使用Curl和JsonCpp调用有道翻译API实现在线翻译, 得到大家的热情捧场,有人看了文章说要是能发声不是更好,我觉得说的也是哈,能听到专家的标准发音,那该是多美的 ...
- 原生js简单调用百度翻译API实现的翻译工具
先来个在线demo: js翻译工具 或者百度搜索js简单调用百度翻译API工具(不过有个小小的界面显示bug,我想细心的人应该会发现) 或者直接前往该网址:js翻译工具 或者前往我的github:gi ...
- 百度翻译api 实现简易微信翻译小程序
介绍 口袋翻译 口袋翻译 微信小程序 翻译功能 含7类语言的相互翻译 包含最近10条的翻译历史回溯功能 微信搜索:简e翻译 功能展示 使用百度翻译api需要申请 appid 与 key 并在 ap ...
- 15款免费WiFi入侵破解安全测试工具
以下是的15款免费(接近免费)的WiFi网络入侵测试工具.这些工具将帮你发现流氓AP,弱Wi-Fi密码等安全隐患,在黑客光临之前把漏洞补上. 一.Vistumbler扫描器 Kismet是一个开源的W ...
- 基于百度翻译API开发属于自己的翻译工具
你是否每天使用着网页翻译工具?你是否遇到过这种情况,上网过程中遇到一个很长的单词但是又不能复制,要开两个浏览器,一个打开百度翻译,照着另一个网页输入单词?你安装了各种翻译软件后,又删除,只因忍受不了那 ...
随机推荐
- 设计模式学习心得<适配器 Adapter>
适配器模式(Adapter Pattern)是作为两个不兼容的接口之间的桥梁.这种类型的设计模式属于结构型模式,它结合了两个独立接口的功能. 这种模式涉及到一个单一的类,该类负责加入独立的或不兼容的接 ...
- faster-rcnn 笔记
2019-02-18,15点00 ''' 下面是别人写的原始的笔记,我在上面自己补充了一些. ''' #https://www.cnblogs.com/the-home-of-123/p/974796 ...
- Markdown 尝试
目录 简介 参数模型 vs. 非参数模型 创新点 at the modeling level at the training procedure 模型结构 attention kernel Full ...
- UE4的委托
UE中委托的使用很广泛,许多Event的触发都有对应的虚函数和委托,虚函数不用讲,只能在派生类中使用,而委托可以在别的类或者蓝图中使用,就应用范围而言,委托的使用更灵活.以AActor的 /** * ...
- 【Java】基本数据类型
基本知识点给个链接: https://blog.csdn.net/qwe969153746/article/details/53353534 问题: 1.3*0.1 == 0.3 返回什么: fals ...
- js电子表
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- 【Selenium】【BugList9】windows环境,fp = open("./"+ time.strftime("%Y-%m-%d %H:%M:%S") + " result.html",'wb'),报错:OSError: [Errno 22] Invalid argument: './2018-09-05 10:29:32 result.html'
[代码] if __name__=="__main__": suite = unittest.TestSuite() suite.addTest(Baidu("test_ ...
- 使用Jmeter进行http接口做功能、性能测试
在测试移动APP时,会有很多接口需要做测试,我在这里介绍一下对HTTP接口做功能.性能的测试.首先我们会从开发人员拿到接口数据. 一.测试需求描述 1. 本次测试的接口为http服务端接口 2 ...
- Swift 加载 xib 崩溃问题
新版本用 Swift开发 遇到的坑 解决方法
- safari10.0以上版本出现默认小人头图标
1.可能改input输入框外层有兄弟元素在input之前,将input元素位置放置在所有兄弟元素之前即可