Logging HTTP Requests in Python urllib3: Understanding Request Hooks
Write a Python program that uses request hooks to log information about each request made with urllib3.
Sample Solution:
Python Code :
# Import the urllib3 library
import urllib3
# Custom request hook function to log information
def logging_request_hook(response, *args, **kwargs):
# Log information about the response
print(f"Received response with status code: {response.status}")
print(f"Response Headers: {response.headers}")
# Function to make a sample request using the custom hook
def make_sample_request():
# Create a PoolManager with the custom request hook
http = urllib3.PoolManager()
# Define the URL for the sample request
sample_url = 'https://www.example.com'
try:
# Make a GET request using the PoolManager
response = http.request('GET', sample_url, headers={'User-Agent': 'Custom User Agent'},
preload_content=False, retries=False)
# Check if the request was successful (status code 200)
if response.status == 200:
print("Request Successful:")
print(response.data.decode('utf-8'))
else:
print(f"Error: Unable to fetch data. Status Code: {response.status}")
except urllib3.exceptions.RequestError as e:
print(f"Error: {e}")
if __name__ == "__main__":
# Make a sample request with the custom request hook
make_sample_request()
Sample Output:
Request Successful: <!doctype html> <html> <head> <title>Example Domain</title> <meta charset="utf-8" /> <meta http-equiv="Content-type" content="text/html; charset=utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> <style type="text/css"> body { background-color: #f0f0f2; margin: 0; padding: 0; font-family: -apple-system, system-ui, BlinkMacSystemFont, "Segoe UI", "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif; } div { width: 600px; margin: 5em auto; padding: 2em; background-color: #fdfdff; border-radius: 0.5em; box-shadow: 2px 3px 7px 2px rgba(0,0,0,0.02); } a:link, a:visited { color: #38488f; text-decoration: none; } @media (max-width: 700px) { div { margin: 0 auto; width: auto; } } </style> </head> <body> <div> <h1>Example Domain</h1> <p>This domain is for use in illustrative examples in documents. You may use this domain in literature without prior coordination or asking for permission.</p> <p><a href="https://www.iana.org/domains/example">More information...</a></p> </div> </body> </html>
Explanation:
Here's a brief explanation of the above Python urllib3 library code:
- Custom Request Hook Function (logging_request_hook):
- The "logging_request_hook()" function is a custom request hook provided to the urllib3 library.
- It takes the "response" object, which contains information about the HTTP response, as well as additional "args" and "*kwargs" parameters.
- Function to Make a Sample Request (make_sample_request):
- The "make_sample_request()" function demonstrates how to use the custom request hook.
- It creates a PoolManager from urllib3, specifying the custom request hook (hooks={'response': logging_request_hook}).
- Then, it makes a sample GET request to 'https://www.example.com' with a custom User-Agent header.
- The 'preload_content' and 'retries' parameters are set to 'False' to avoid loading the content into memory and disabling retries.
- Execution in the Main Block (`if name == "main":):
- Calls the "make_sample_request()" function when the script is executed.
- Output:
- The custom request hook logs information about the received response, including the status code and headers.
Flowchart:
Python Code Editor :
Have another way to solve this solution? Contribute your code (and comments) through Disqus.
Previous: Constructing URLs with Python urllib3: Query Parameter Encoding Explained.
Next: Making API Requests with digest authentication in Python urllib3.
What is the difficulty level of this exercise?
Test your Programming skills with w3resource's quiz.
- Weekly Trends and Language Statistics
- Weekly Trends and Language Statistics