在python中使用套接字的HTTP基本身份验证

时间:2010-05-28 13:50:18

标签: python networking sockets basic-authentication

如何使用python中的基本http auth thru套接字连接到服务器。我不想使用urllib / urllib2等,因为我的程序执行一些低级套接字I / O操作

2 个答案:

答案 0 :(得分:5)

最容易开始的地方可能是使用makefile()来获得更简单的类似文件的套接字接口。

import socket, base64

host= 'www.example.com'
path= '/'
username= 'fred'
password= 'bloggs'
token= base64.encodestring('%s:%s' % (username, password)).strip()

lines= [
    'GET %s HTTP/1.1' % path,
    'Host: %s' % host,
    'Authorization: Basic %s' % token,
    'Connection: close',
]

s= socket.socket()
s.connect((host, 80))
f= s.makefile('rwb', bufsize=0)
f.write('\r\n'.join(lines)+'\r\n\r\n')
response= f.read()
f.close()
s.close()

如果您需要解释返回的响应以选择HTML或auth-required标头,并处理重定向,错误,传输编码等等,那么您将需要做更多的工作。 HTTP可能很复杂!你确定需要使用低级套接字吗?

答案 1 :(得分:2)

看看,例如在urllib的sources,特别是http_error_401函数(当然还有调度):发出HTTP请求,注意401响应,提取其领域,检查其方案是{{1} ,再次使用该领域的用户和密码(同一源文件中的cfr函数basic)。当然还有很多工作要做,但这就是你需要编程“直到裸机”的代价。

相关问题