Python 中的POST/GET包构建以及随机字符串的生成-乾颐堂

现在,我们来用Python,创建GET包和POST包。

至于有什么用处,大家慢慢体会。

Python 中包含了大量的库,作为一门新兴的语言,Python 对HTTP有足够强大的支持。

现在,我们引入新的库 httplib 以及 urllib

这两个库根据名称,我们可以知道他们是对于HTTP以及URL的操作。

首先我们先要与服务器建立连接。(我们以某微博作为例子实现下文的各种功能)

conn = httplib.HTTPConnection("ti50*****com");

只要没有提示错误,我们就可以认为连接已成功,下面就可以进行数据包发送了。

在上文中我们说过了GET包的结构,只有HEARDER 部分。而在httplib中,heaer 是通过一个字典来保存的。下面我们来定义它:

headers = {"Content-Type": "application/x-www-form-urlencoded",

"Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8",

"Referer": "http://ti50.*****com/g/s?sid=*********************",

"Accept-Encoding": "",

"Accept-Language": "zh-CN,zh;q=0.8",

"Accept-Charset": "GBK,utf-8;q=0.7,*;q=0.3",

"Cookie": Cookie  }

Accept-Encoding 我们删除了其内容,这对于服务器来说我们客户端不能接受任何压缩的格式,数据包将用原始数据发送回来,这样我们就可以省去解压缩的过程直接分析网页了,但是这样做的后果是流量大,网络实时性差。关于解压缩自然有别的库来专门处理。

然后我们可以直接发送了。

conn.request(method="GET",url=‘‘‘http://ti50****com/g/s?*********_TK9EH&r=‘‘‘ + go_num + ‘‘‘&aid=amsg&bid=******=true&ifh=1&ngpd=false‘‘‘,headers=headers);

method 字段说明是发送何种类型的数据包。

url 字段以字符串的形式定义地址

header 字段定义包头。

一般来说,一个数据包发送至服务器,服务器会相应的返回一个应答包。而且这个应答包对于我们往往是有用的,我们用下面的命令获取应答包。

response = conn.getresponse();

对于上面这条语句中的括号,其表示读取应答包的前多少个字符。

POST包与GET包的创建过程基本相同。

只是我们需要新定义BODY,这个部分可以用字符串的方式进行定义。

params = ‘msg=***************************‘

我们仍然需要先于服务器进行连接。

conn = httplib.HTTPConnection("ti50*****com");

发送

conn.request(method="POST",url=‘‘‘/g/s?sid=******************&ngpd=false‘‘‘,body=params,headers=headers);

可以发现上面的这个公式和发送GET包的格式略有差距。

method 改变了。

url 里面没有写域名。

多了一个body 字段。

其中第二条可以想到,如果没定义域名,则系统将最近一次与服务器的连接用的域名进行替换。

获取应答包的方式与GET包相同。

乱七八糟的小应用。

(一) 随机字符串的生成。

当我们用POST做一些很有趣的事情时,常常会遇到服务器验证神马的,有时候我们可以用随机字符串来处理这样的情况。

python 中给了随机数的库…… random。

对于简单的应用非常方便。例如我们产生a与b 之间的一个随机整数。

random.randint(a,b)

>>> random.randint(10,20)

>>> 15

知道了这步,我们可以很简单的编写一个随机字符串的程序了,


1

2

3

4

5

6

7

8

9

from random import Random 

def random_str(randomlength): 

    str = ‘‘ 

    chars = ‘AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz0123456789‘

    length = len(chars) - 1

    random = Random() 

    for i in range(randomlength): 

        str+=chars[random.randint(0, length)] 

    return str

显然当调用此函数时应该给出随机字符串长度。

当然,我们也可以通过修改chars中的字符来定义随机字符串中的字符。

(二) 程序运行时间

我们现在给出一个非常不精确的程序时间计算方法,


1

2

3

4

5

from time import clock as now

start = now()

finish = now()

run_time = finish - start

print run_time

www.qytang.com/
http://www.qytang.com/cn/list/29/
http://www.qytang.com/cn/list/28/446.htm
http://www.qytang.com/cn/list/28/445.htm
http://www.qytang.com/cn/list/28/444.htm
http://www.qytang.com/cn/list/28/442.htm
http://www.qytang.com/cn/list/28/440.htm
http://www.qytang.com/cn/list/28/437.htm
http://www.qytang.com/cn/list/28/435.htm
http://www.qytang.com/cn/list/28/434.htm
http://www.qytang.com/cn/list/28/433.htm
http://www.qytang.com/cn/list/28/431.htm
http://www.qytang.com/cn/list/28/328.htm
http://www.qytang.com/cn/list/28/326.htm
http://www.qytang.com/cn/list/28/429.htm

时间: 2024-10-25 22:23:38

Python 中的POST/GET包构建以及随机字符串的生成-乾颐堂的相关文章

Python 中的时间处理包datetime和arrow

Python 中的时间处理包datetime和arrow 在获取贝壳分的时候用到了时间处理函数,想要获取上个月时间包括年.月.日等 # 方法一: today = datetime.date.today() # 1. 获取「今天」 first = today.replace(day=1) # 2. 获取当前月的第一天 last_month = first - datetime.timedelta(days=1) # 3. 减一天,得到上个月的最后一天 print(last_month.strfti

Python中模块(Module)和包(Package)的区别

1. 模块(Module) 在计算机程序的开发过程中,随着程序代码越写越多,在一个文件里代码就会越来越长,越来越不容易维护. 为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文件包含的代码就相对较少,很多编程语言都采用这种组织代码的方式.在Python中,一个.py文件就称之为一个模块(Module). 使用模块有什么好处? 最大的好处是大大提高了代码的可维护性.其次,编写代码不必从零开始.当一个模块编写完毕,就可以被其他地方引用.我们在编写程序的时候,也经常引用其他模

python高性能编程方法一-乾颐堂

阅读 Zen of Python,在Python解析器中输入 import this. 一个犀利的Python新手可能会注意到"解析"一词, 认为Python不过是另一门脚本语言. "它肯定很慢!" 毫无疑问Python程序没有编译型语言高效快速. 甚至Python拥护者们会告诉你Python不适合这些领域. 然而,YouTube已用Python服务于每小时4千万视频的请求. 你所要做的就是编写高效的代码和需要时使用外部实现(C/C++)代码. 这里有一些建议,可以

python时间处理详解-乾颐堂

1.获取当前时间的两种方法: import datetime,time now = time.strftime("%Y-%m-%d %H:%M:%S") print now now = datetime.datetime.now() print now 2.获取上个月最后一天的日期(本月的第一天减去1天) last = datetime.date(datetime.date.today().year,datetime.date.today().month,1)-datetime.tim

python中、模块、包初识

模块:逻辑上组织python代码(变量.函数.类.逻辑:实现功能),以.py为结尾的python文件.(test.py 文件,对应的模块名:test) 包:用来从逻辑上组织模块的,本质就是一个目录(带有__init__.py的文件). 导入方法: import test from test import * from test import name,age from test import name as name_test //从test中导入name变量后,变量名更改为name_test

Python中的参数解包:`*`表达式和 `**`表达式

目录 1.参数解包:方法调用中的*表达式和**表达式 2.参数解包:方法定义中的*表达式和**表达式 3.在元组,列表,集合和字典中解包 4.Extended Unpacking:赋值表达式左边的*表达式 1.参数解包:方法调用中的*表达式和**表达式 如果语法*表达式出现在函数调用中,则该表达式必须是可迭代的. 这些可迭代集合的元素被视为附加的位置参数. 对于调用f(x1, x2, *y, x3, x4),如果y等于序列[y1,...,yM],则等效于调用f(x1, x2, y1, ...,

python中repr和eval可以用来在数据结构和字符串间互转

在这个功能上,repr和str的作用一样,把一个数据结构转换成字符串,例如: >>> str([1,2,3,4])'[1, 2, 3, 4]' >>> repr([1,2,3,4])'[1, 2, 3, 4]' eval是把字符串转换成数据结构,例如:>>> eval('[1,2,3,4]')[1, 2, 3, 4] 这个比较实用,在读取到某些代表数据结构的字符串时,可以直接转成对应的结构,例如列表.元祖.字典.json等 原文地址:https://w

在python中,列表,元组,字典,字符串之间是可以互相转换的

list1=['name','age','address'] print('把列表list1转换为字符串:',str(list1))print(type(str(list1)) str='wuya name sex age' print ('把字符串str转换为列表:',str.split(' '))print('类型为:',type(str.split(' ')) print ('把列表list1转换为元组:',tuple(list1))print('类型为:',type(tuple(list

Python服务器开发 -- 网络基础-乾颐堂

网络由下往上分为物理层.数据链路层.网络层.传输层.会话层.表示层和应用层. HTTP是高层协议,而TCP/IP是个协议集,包过许多的子协议.包括:传输层的 FTP,UDP,TCP协议等,网络层的ip协议等,高层协议如HTTP,telnet协议等,HTTP是TCP/IP的一个子协议. socket是对TCP/IP协议的封装和应用(程序员层面上).也可以说,TPC/IP协议是传输层协议,主要解决数据如何在网络中传输,而HTTP是应用层协议,主要解决如何包装数据. 我们在传输数据时,可以只使用(传输