| You are here: Inicio > Inmersión en Python > Servicios Web HTTP > Todo junto | << >> | ||||
Inmersión en PythonPython de novato a experto |
|||||
Ya hemos visto todas las partes necesarias para construir un cliente inteligente de servicios web HTTP. Ahora veamos cómo encaja todo.
Esta función está definida en openanything.py.
def openAnything(source, etag=None, lastmodified=None, agent=USER_AGENT): # se omite el código no relativo a HTTP por brevedad if urlparse.urlparse(source)[0] == 'http':# open URL with urllib2 request = urllib2.Request(source) request.add_header('User-Agent', agent)
if etag: request.add_header('If-None-Match', etag)
if lastmodified: request.add_header('If-Modified-Since', lastmodified)
request.add_header('Accept-encoding', 'gzip')
opener = urllib2.build_opener(SmartRedirectHandler(), DefaultErrorHandler())
return opener.open(request)
![]()
Esta función está definida en openanything.py.
def fetch(source, etag=None, last_modified=None, agent=USER_AGENT): '''Fetch data and metadata from a URL, file, stream, or string''' result = {} f = openAnything(source, etag, last_modified, agent)result['data'] = f.read()
if hasattr(f, 'headers'): # save ETag, if the server sent one result['etag'] = f.headers.get('ETag')
# save Last-Modified header, if the server sent one result['lastmodified'] = f.headers.get('Last-Modified')
if f.headers.get('content-encoding', '') == 'gzip':
# data came back gzip-compressed, decompress it result['data'] = gzip.GzipFile(fileobj=StringIO(result['data']])).read() if hasattr(f, 'url'):
result['url'] = f.url result['status'] = 200 if hasattr(f, 'status'):
result['status'] = f.status f.close() return result
>>> import openanything >>> useragent = 'MyHTTPWebServicesApp/1.0' >>> url = 'http://diveintopython.org/redir/example301.xml' >>> params = openanything.fetch(url, agent=useragent)>>> params
{'url': 'http://diveintomark.org/xml/atom.xml', 'lastmodified': 'Thu, 15 Apr 2004 19:45:21 GMT', 'etag': '"e842a-3e53-55d97640"', 'status': 301, 'data': '<?xml version="1.0" encoding="iso-8859-1"?> <feed version="0.3" <-- rest of data omitted for brevity -->'} >>> if params['status'] == 301:
... url = params['url'] >>> newparams = openanything.fetch( ... url, params['etag'], params['lastmodified'], useragent)
>>> newparams {'url': 'http://diveintomark.org/xml/atom.xml', 'lastmodified': None, 'etag': '"e842a-3e53-55d97640"', 'status': 304, 'data': ''}
![]()
| La primera vez que pedimos un recurso no tenemos suma ETag o fecha Last-Modified, así que no las incluimos. (Son parámetros opcionales.) | |
| Lo que obtenemos es un diccionario de varias cabeceras útiles, el código de estado HTTP y los datos en sí devueltos por el servidor. openanything trata la compresión gzip internamente; no tenemos que preocuparnos de eso a este nivel. | |
| Si alguna vez obtenemos un código de estado 301, eso es una redirección permanente y necesitamos actualizar la URL a la nueva dirección. | |
| La segunda vez que pedimos el mismo recurso, tenemos todo tipo de información para acompañar: Una URL (posiblemente actualizada), la ETag y la fecha Last-Modified de la última vez, y por supuesto nuestra User-Agent. | |
| De nuevo lo que obtenemos es un diccionario, pero los datos no han cambiado, así que todo lo que obtenemos es un código de estado 304 sin datos. |
<< Tratamiento de datos comprimidos |
| 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | |
Resumen >> |