Book Image

Building RESTful Python Web Services

By : Gaston C. Hillar
Book Image

Building RESTful Python Web Services

By: Gaston C. Hillar

Overview of this book

Python is the language of choice for millions of developers worldwide, due to its gentle learning curve as well as its vast applications in day-to-day programming. It serves the purpose of building great web services in the RESTful architecture. This book will show you the best tools you can use to build your own web services. Learn how to develop RESTful APIs using the popular Python frameworks and all the necessary stacks with Python, Django, Flask, and Tornado, combined with related libraries and tools. We will dive deep into each of these frameworks to build various web services, and will provide use cases and best practices on when to use a particular framework to get the best results. We will show you everything required to successfully develop RESTful APIs with the four frameworks such as request handling, URL mapping, serialization, validation, authentication, authorization, versioning, ORMs, databases, custom code for models and views, and asynchronous callbacks. At the end of each framework, we will add authentication and security to the RESTful APIs and prepare tests for it. By the end of the book, you will have a deep understanding of the stacks needed to build RESTful web services.
Table of Contents (18 chapters)
Building RESTful Python Web Services
Credits
About the Author
Acknowledgments
About the Reviewer
www.PacktPub.com
Preface

Test your knowledge


  1. The concurrent.futures.ThreadPoolExecutor class provides us:

    1. A high-level interface for synchronously executing callables.

    2. A high-level interface for asynchronously executing callables.

    3. A high-level interface for composing HTTP requests.

  2. The @tornado.concurrent.run_on_executor decorator allows us to:

    1. Run an asynchronous method synchronously on an executor.

    2. Run an asynchronous method on an executor without generating a Future.

    3. Run a synchronous method asynchronously on an executor.

  3. The recommended way to write asynchronous code in Tornado is to use:

    1. Coroutines.

    2. Chained callbacks.

    3. Subroutines.

  4. The tornado.Testing.AsyncHTTPTestCase class represents:

    1. A test case that starts up a Flask HTTP Server.

    2. A test case that starts up a Tornado HTTP Server.

    3. A test case that doesn't start up any HTTP Server.

  5. If we want to convert the bytes in a JSON response body to a Python dictionary, we can use the following function:

    1. tornado.escape.json_decode

    2. tornado.escape.byte_decode

    3. tornado.escape...