本小案例,通过有道词典的查询,模拟post请求的过程:
在浏览器和服务器交互过程中Get和Post的区别
Get:请求URL会附带查询参数;
POST:请求的URL不带参数;
对于Get的请求:查询参数在QueryString里面保存
对于Post请求:查询参数在Form表单里面保存
程序中的url,headers,formdata表单是通过Fiddler网络抓包获取的;因为有道网页会反爬虫,相关的表单参数会又所变化。说以要学会在Fiddler种灵活获取相关的表单。
表单在sublime text环境下操作比较方便,正则表达式批量替换,其中^:行开头,$:行尾(这样表示是以每一行的形式替换的)
^(.*)=(.*)$
"\1":"\2",
如果中间有空格的话,用\s
实现例程如下:
#!/usr/bin/env python
# coding=utf-8
import urllib
import urllib2
#通过抓包方式获取的url地址,不是浏览器上的
url="http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule"
headers={
#"connection":"keep-alive",
# "accept":"application/json, text/javascript, */*; q=0.01",
#"origin":"http://fanyi.youdao.com",
# "X-requested-with":"XMlhtTprequest",
"user-agent":"mozilla/5.0 (windowS NT 10.0; win64; x64) appLewEbkit/537.36 (KHTML, likE gecko) chrome/65.0.3325.181 safari/537.36",
# "content-type":"application/x-www-form-urlencoded; charseT=UTF-8",
#"Referer":"http://fanyi.youdao.com/",
#"accept-encoding":"gzip, deflate",
#"accept-language":"zH-Cn,zh;q=0.9",
}
key=raw_input("请输入需要翻译的文字")
formdata={
"i":key,
"from":"AUTO",
"to":"AUTO",
"smartresult":"dict",
"client=fanyideskweb&salt":"1521723770649",
"sign":"56b154bafdf19e0e5cf5bd6efff5c279",
"doctype":"json",
"version":"2.1",
"keyfrom=fanyi.web&action":"FY_BY_CLICKBUTTION",
"typOresult":"false",
}
#转码,因为发送的时候就是url编码格式发送的
data=urllib.urlencode(formdata)
#print data
request=urllib2.Request(url,data=data,headers=headers)
context=urllib2.urlopen(request).read()
print context
测试运行的时候报错误:{"errorCode":50},
之后把POST http://fanyi.youdao.com/translate_o?smartresult=dict&smartresult=rule 的url地址中的‘o’字段去掉,问题就解决了
来源:CSDN
作者:A哥
链接:https://blog.csdn.net/u011688982/article/details/79660585