采用抓包的方式逆向获得谷歌翻译的API
文章目录
- 最开始的尝试
- 2022.12.26
- 谷歌翻译API相关信息
- 发送网址
- 提交的数据
- 不过不出意外的失败了
- 实验
- 去掉参数
- 去掉Headers
- 代码
- 对返回结果进行解析
- 完整代码
最开始的尝试
谷歌的翻译API老是发生变化,我们需要自己动手来找到谷歌的翻译API,这样才是最稳妥的解决方法
首先,用谷歌浏览器打开谷歌的翻译界面,看一下它是怎么请求数据的
右键检查,进入开发者工具,选择网络(network),如图所示
点击clear清除,把之前所有的请求视觉上清空,方便我们后续查找真正的API请求
谷歌翻译大约每秒会请求一次,我们很快就可以得到谷歌服务器返回给我们的翻译结果,经过排查,下面的这个batchexecute开头的请求就是我们需要的,
我们点开对其进行进一步分析,可以看到这是一个post的请求
从载荷中可以看到发送post请求时使用的参数,是一个表单数据
从预览中可以看到翻译的结果,是一个JSON格式的数据
2022.12.26
上面的方法是适用的,只不过是现在这个接口没有以前好找了,我们使用谷歌搜索引擎上提供的谷歌翻译来找这个接口
我们先在网页端测试一个翻译,可以看到这个结果反馈回来了
这是一个post请求,自己下一个网址发送自己需要翻译的文本,服务器就会给自己反馈回来对应的结果
谷歌翻译API相关信息
发送网址
### https://www.google.com/async/translate?vet=12ahUKEwjp-9mwmZf8AhXT0GEKHQc7Cs8QqDh6BAgFECw..i&ei=6YepY6njDdOhhwOH9qj4DA&yv=3&cs=0
- 这个网址虽然很长,但核心部分应该只是
### https://www.google.com/async/translate
- 后面的参数都是没有太大用处的,不过我们这里先做保留,之后再做精简验证
提交的数据
### async=translate,sl:zh-TW,tl:zh-CN,st:1111,id:1672054875193,qc:true,ac:true,_id:tw-async-translate,_pms:s,_fmt:pc
- 使用postman构造一个post的请求
不过不出意外的失败了
- 返回的是一个404的网页,而不是自己想要的翻译结果,
- 我猜测应该是没有添加cookie的关系,我们在参数里面添加一下cookie
- 但没想到添加cookie之后依然失败
实验
去掉参数
- 将所有的参数去掉之后,发现仍然可以正常得到结果
去掉Headers
去掉Content-Length之后就无法返回结果了 #设置的headers参数不够
结论:headers里面的参数应该尽可能多一点,最好把原请求中的所有参数都带过来
写成对应的Python代码
代码
import requests url = "https://www.google.com.hk/async/translate" payload = "async=translate,sl:en,tl:zh-CN,st:1111,id:1672056488960,qc:true,ac:true,_id:tw-async-translate,_pms:s,_fmt:pc"
headers = { 'sec-ch-ua': '"Not?A_Brand";v="8", "Chromium";v="108", "Google Chrome";v="108"', 'DNT': '1', 'sec-ch-ua-mobile': '?0', 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36', 'sec-ch-ua-arch': '"x86"', 'sec-ch-ua-full-version': '"108.0.5359.125"', 'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8', 'sec-ch-ua-platform-version': '"10.0.0"', 'sec-ch-ua-full-version-list': '"Not?A_Brand";v="8.0.0.0", "Chromium";v="108.0.5359.125", "Google Chrome";v="108.0.5359.125"', 'sec-ch-ua-bitness': '"64"', 'sec-ch-ua-model': '', 'sec-ch-ua-wow64': '?0', 'sec-ch-ua-platform': '"Windows"', 'Accept': '*/*', 'X-Client-Data': 'CKW1yQEIhbbJAQiktskBCMS2yQEIqZ3KAQjb08oBCLD+ygEIlaHLAQjv8swBCN75zAEI5PrMAQjxgM0BCLKCzQEI7ILNAQjIhM0BCO+EzQEIt4XNAQ==', 'Sec-Fetch-Site': 'same-origin', 'Sec-Fetch-Mode': 'cors', 'Sec-Fetch-Dest': 'empty', 'host': 'www.google.com.hk', 'Cookie': '1P_JAR=2022-12-26-12; NID=511=eVLI1bG9nhyOZtqU14JBHm5Be00epdxfR4XmfQeehYyIkzgpXi6dbpNY75ZMVyS7aOjoM2oZ5WdoR8eNq6wi1-e_J0NeoyI0dtsHW-_8Ik4PGrqvuGHdcvVC03zTOEK2TY1FZL85Wimo_ZPIE3hGIrmGPSiel6-rRRW9lD30UPs'
} response = requests.request("POST", url, headers=headers, data=payload) print(response.text)
- 可以正常返回我们现在的结果,
- 但这个结果还不是我们想要的,我们需要对其进行一并的解析
对返回结果进行解析
- 其实也很好定位,就是找到
<span id="tw-answ-target-text">
和</span>
之间的文本即可
- 提取完之后非常nice
完整代码
def Google_Translate(origin_string): import requests url = "https://www.google.com.hk/async/translate" payload = "async=translate,sl:en,tl:zh-CN,st:{},id:1672056488960,qc:true,ac:true,_id:tw-async-translate,_pms:s,_fmt:pc".format(origin_string) headers = { 'sec-ch-ua': '"Not?A_Brand";v="8", "Chromium";v="108", "Google Chrome";v="108"', 'DNT': '1', 'sec-ch-ua-mobile': '?0', 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36', 'sec-ch-ua-arch': '"x86"', 'sec-ch-ua-full-version': '"108.0.5359.125"', 'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8', 'sec-ch-ua-platform-version': '"10.0.0"', 'sec-ch-ua-full-version-list': '"Not?A_Brand";v="8.0.0.0", "Chromium";v="108.0.5359.125", "Google Chrome";v="108.0.5359.125"', 'sec-ch-ua-bitness': '"64"', 'sec-ch-ua-model': '', 'sec-ch-ua-wow64': '?0', 'sec-ch-ua-platform': '"Windows"', 'Accept': '*/*', 'X-Client-Data': 'CKW1yQEIhbbJAQiktskBCMS2yQEIqZ3KAQjb08oBCLD+ygEIlaHLAQjv8swBCN75zAEI5PrMAQjxgM0BCLKCzQEI7ILNAQjIhM0BCO+EzQEIt4XNAQ==', 'Sec-Fetch-Site': 'same-origin', 'Sec-Fetch-Mode': 'cors', 'Sec-Fetch-Dest': 'empty', 'host': 'www.google.com.hk', 'Cookie': '1P_JAR=2022-12-26-12; NID=511=eVLI1bG9nhyOZtqU14JBHm5Be00epdxfR4XmfQeehYyIkzgpXi6dbpNY75ZMVyS7aOjoM2oZ5WdoR8eNq6wi1-e_J0NeoyI0dtsHW-_8Ik4PGrqvuGHdcvVC03zTOEK2TY1FZL85Wimo_ZPIE3hGIrmGPSiel6-rRRW9lD30UPs' } response = requests.request("POST", url, headers=headers, data=payload) def find_string_between_A_amd_B(string, string_A, string_B): # 查找两段字符串之间的字符 import re regular = '{}(.*?){}'.format(string_A, string_B) result = re.findall(regular, string) return result result = find_string_between_A_amd_B(response.text, '', '') return result result = Google_Translate('222')
print("result:", result)
return result
result = Google_Translate(‘222’)
print(“result:”, result)
[外链图片转存中...(img-nfuTyPwt-1672058973251)]
[外链图片转存中...(img-ICHoHbvS-1672058973252)] #
采用抓包的方式逆向获得谷歌翻译的API相关推荐
- Python使用网络抓包的方式,利用超级鹰平台识别验证码登录爬取古诗文网、上篇--识别验证码
Python使用网络抓包的方式,利用超级鹰平台识别验证码登录,<爬取古诗文网>. 上篇–识别验证码 序言: 哈喽,各位小可爱们,我又来了,这次我新学习到的内容是python爬虫识别验证码. ...
- Python进阶篇:百度指数解密【抓包|JS逆向|数据区分】
前言 大家好,我是辣条哥~ 过往给大家更新了不少基础相关的,今天给大家上点硬货,基础不好的慎入,免得打击你们的积极性~ 其次对数据分析|数据可视化|pandas感兴趣的可以来这里刷刷题: →→→< ...
- Python进阶篇:百度指数解密【抓包JS逆向数据区分】
前言 大家好,我是辣条哥~ 过往给大家更新了不少基础相关的,今天给大家上点硬货,基础不好的慎入,免得打击你们的积极性~ 其次对数据分析|数据可视化|pandas感兴趣的可以来这里刷刷题: →→→< ...
- java实现FTP协议:wireshark抓包解析
本节我们看看ftp协议的数据包格式,同时使用代码加以实现.首先我们现在机器上安装ftp服务器,我在自己的机器上安装了QuickFTP Server,它是我随便找来的一款Mac ftp服务器,如下图所示 ...
- 控制台抓包和requests.post()发送请求
控制台抓包 打开方式及常用选项 1.打开浏览器,F12打开控制台,找到Network选项卡 2.控制台常用选项 1.Network: 抓取网络数据包 1.ALL: 抓取所有的网络数据包 2.XHR:抓 ...
- 抓包工具:教你搞懂websocket如何来分析
之前负责完成公司的消息推送服务,和移动端配合完成了扫码登录.订单消息推送.活动消息广播等功能.为了加深对Websocket协议的理解,通过进行抓包的方式学习了一番.现在分享出来,希望对大家能有所帮助. ...
- HTTP抓包分析——结合Firefox浏览器原理
目录 全程实际操作,多图警告!!! 想基本还原实验场景的同学可以私信我,把har文件发你 前提 html加载 请求头 响应头 第二步,接着分析文件类型 图片懒加载 域名和文件类型 304缓存 进一步分 ...
- IOS系统抓包之短链-破解双向证书
前言 上次文章iOS系统抓包入门实践之短链有说道关于常规抓包.路由直连以及单向证书校验的抓包方式,该文章将是在短链抓包中进行补充,主要是针对短链抓包中不太经常用到的双向证书,并进行破解和通过Charl ...
- 怎样对Android设备进行网络抓包
问题描写叙述: 前段时间自己的app訪问server的url总是会出现间接性失败的问题,于是和server的同事开了个会.提出了他们server存在的这个bug,我的同事自然说自己的server没问题 ...
最新文章
- vs2010设置boost开发环境
- webstrom常用键
- Linux中设置服务自启动的三种方式
- 利用CodeIgniter中的Email类发邮件
- 查看真实的执行计划 绑定变量对执行计划的影响--“绑定变量窥探”
- 程序员面试题精选100题(20)-最长公共子串[算法]
- 【CyberSecurityLearning 24】kali中间人攻击
- ECCV 2020《TRRNet: Tiered Relation Reasoning for Compositional Visual Question Answering》论文笔记
- java : nio 学习
- php格式化输出字_PHP 输出格式化字符串
- QT小项目-基于百度API的在线词典
- linux tar文件夹打包不包含目录,tar打包如何不打包某一个文件夹(排除某些文件夹)...
- 微信小程序——组件库
- 新萝卜家园 GhostXP SP3 电脑城装机版 V2011.07
- 基于微信公众平台的智能硬件/智能设备APP开发详解
- 如何写好项目规划和方案设计文档
- 显卡1060和1660测试对比
- MyBatis万能插入语句
- 使用Python的psutil包获取机器IPv4信息
- 计算机硬件软件的学习
热门文章
- 2小时破解WIFI密码!WPS漏洞目前尚无解决方案
- Python pygame(GUI编程)模块最完整教程(1)
- 《动手学深度学习Pytorch版》中‘d2lzh_pytorch‘模块问题
- 《动手学深度学习》(PyTorch版)避坑总结 - 1 【d2lzh_pytorch模块导入方法详解及提示错误的解决方法】
- 基于爬行动物搜索RSA优化LSTM的时间序列预测
- WinForm 子窗体 调用 父窗体 方法
- Unicode等各种码的汇总
- vscode 配置代码格式化工具calng-format,windows/linux都支持
- 一斤鸡蛋一毛钱?一个月卖了100多万,95后小姑娘的连环方案!
- Java实现RPG游戏(mini版pokemon)