This page permanently redirects to gemini://complete.org/foundations-of-python-network-programming/.

Foundations of Python Network Programming

Foundations of Python Network Programming is now available for purchase (Amazon[1]). This book is designed to show you everything from fundamentals of networking and low-level protocol design to work with higher-level protocols such as IMAP, HTTP, and FTP. For more information, please see the letter to the reader from the book's back cover[2].

=> 1: http://www.amazon.com/gp/product/1590593715 | 2: /ox-hugo/pynet-back.png

This is not a basic reference like Python comes with. Rather, it's a hands-on guide. There are over 6600 lines of example code and the text strives to show you the big picture. For instance, there are several different ways of getting directory information from an FTP server, and some are not documented for use this way. The chapter on FTP explains them and provides example code to illustrate. There's also a blog page[3] for your comments.

=> 3: http://changelog.complete.org/articles/2004/08/25/foundations-of-python-network-programming/

Reviews

There have been several reviews of this book. Here are some links:

Slashdot has a review[4] giving the book a 9 out of 10. One quote: "This may be the easiest review I've ever written. If you program in Python and you want to write Internet applications, go buy Foundations of Python Network Programming."

=> 4: http://books.slashdot.org/books/04/10/13/1815209.shtml?tid=192&tid=6

On Amazon, the book has a user rating of 4.5 out of 5. The editorial review mentions that "This book features extensive examples that not only demonstrate important concepts and practices, but also provide a cadre of fully-functional standalone programs." The editorial review, as well as user reviews, are both available on the book's Amazon page[5].

=> 5: http://www.amazon.com/gp/product/1590593715

Table of Contents

Below is the book's Table of Contents along with a partial list of the examples you'll find in each chapter:

Part I: Low-Level Networking

Provides basic concepts of TCP/IP networking for those new to it. Examples include very basic versions of: Gopher client, URL downloading program.

Constructing basic network clients: setting up sockets, connecting to servers, sending/receiving data, handling errors. Covers TCP and UDP. Examples include: connecting to servers, error handling, obtaining the exact current time from a UDP network time server.

Constructing basic network servers: binding to a port, listening, handling connections, logging, socket options, inetd servers. Handling multiple simultaneous connections is covered in Part VI. Examples include: TCP and UDP echo servers, TCP echo client, TCP and UDP inetd servers.

Advanced DNS topics: reverse lookups, advanced forward lookups, information about the local system. Examples include various DNS query and lookup utilities.

Advanced network topics that are usually applicable to both client and servers: half-open sockets, timeouts, network byte order, broadcasts, IPv6. Examples include: UDP broadcast sending and receiving programs, binding to specific interfaces, IPv6 HTTP client, network byte order example, cross-protocol DNS lookups.

Part II: Web Services

Obtaining documents from a Web server. Examples include: obtaining information from headers, submitting GET and POST forms, handling errors, and dumping pages.

Parsing HTML documents. Examples include: basic parsing, obtaining the weather forecast for a region.

Handling XML documents and communicating with XML-RPC servers. Examples include: DOM tree parsing and mainpulation, XML-RPC news reader, interactive XML-RPC introspection client.

Part III: E-Mail

Generating message headers and bodies. Using MIME to represent attachments, data encodings, header languages, etc. Examples include: date parsing, MIME decoding, attachments, multipart messages, header generation and parsing, MIME and non-MIME generation.

Using the Simple Mail Transfer Protocol to transmit messages to remote servers. Covers topics such as establishing a connection, authentication, SSL/TLS, setting recipients, etc. Examples include: mail transmission program, TLS support.

Downloading mail using the simple POP3 protocol. Examples include: mailbox information, download messages, delete messages.

A detailed look at the IMAP protocol, including basic connections, authentication methods, folder lists and selection, message searching, flag handling, message retrieval, message storage and copying, and UID handling. Presents the Twisted IMAP4Client library and a brief coverage of the built-in imaplib. Examples include: error handling, uploading messages, downloading messages, deleting messages, message structure, searching, more.

Part IV: General-Purpose Client Protocols

Using the popular protocol to transfer files, get directory listings, discover information about remote files, handle passive mode connects. Examples include: a basic recursive-download FTP client, directory parsing.

Using Python's DB-API 2.0 to connect to database servers. Provides general DB-API background and specific examples using MySQL and PostgreSQL, and the zxJDBC connector. Examples include: connecting, querying, various ways of accessing the result set.

Provides a primer on the potential attacks network programs can face and ways to help reduce them by using SSL. Covers the standard socket.ssl in Python and the more powerful PyOpenSSL. Includes coverage and example code to implement key/certificate verification. Examples include: basic use of the libraries, verification.

Part V: Server-Side Frameworks

Covers this basic infrastructure for writing TCP servers. Includes coverage of BaseHTTPServer and CGIHTTPServer as well as the mix-in classes for forking and threading. Examples include: time server, IPv6 support, HTTP servers.

Shows how to write your own XML-RPC server and interface it to new or existing code. Also covers derivitaves of SimpleXMLRPCServer. Examples include: math server, introspection support.

Explains how CGI fits in with a Web server, covering escaping, form processing, cookie handling, and document generation. Examples include: interactive quiz program, environment.

This Apache module embeds a Python interpreter into the web server. It can be used not just to accelerate dynamic Web sites but also to customize the behavior of Apache itself. Examples include: interactive quiz program, escaping, versatile dispatching system.

Part VI: Multitasking

Covers the use of forking on Unix platforms under Python. Describes the mechanics of forking, different ways to handle dying child processes, error handling, locking, performance, and implications for server authors. Examples include: echo server, zombie process examples.

Covers the use of threading on multiple supported Python platforms. Describes the mechanics of threading, error handling, locking, performance, and implications for server authors. Examples include: echo server, semaphores, thread pools, multi-threaded client.

Covers the use of poll() to achieve the appearance of a multitasking server without using either forking or threading. It goes on to cover the higher-level Twisted libraries. Examples include: echo server, an inetd server, chat server.


Links to this note

=> 6: /john-goerzen-s-publications/

Here is information on papers, documentation, and publications written by John Goerzen[7].

=> 7: /john-goerzen/

=> 8: /john-goerzen/

I am a programmer, manager, hobbyist, advocate, volunteer, dad, and nature lover. I live out on an old farmstead in rural Kansas[9] that once belonged to my grandparents. The nearest paved road is about 3 miles away, and the nearest town (population 600) is 7 miles away. I have three incredible children, which I might occasionally mention on my blog[10].

=> 9: /kansas/ | 10: https://changelog.complete.org/

More on www.complete.org

=> Homepage
=> Interesting Topics
=> How This Site is Built
=> About John Goerzen
=> Web version of this site

(c) 2022-2024 John Goerzen

Proxy Information
Original URL
gemini://complete.org/foundations-of-python-network-programming
Status Code
Success (20)
Meta
text/gemini; charset=utf-8; lang=en; size=9752
Capsule Response Time
868.41813 milliseconds
Gemini-to-HTML Time
1.934508 milliseconds

This content has been proxied by September (ba2dc).