| 
									
										
										
										
											1998-08-10 19:42:37 +00:00
										 |  |  | \section{\module{base64} --- | 
					
						
							| 
									
										
										
										
											1999-02-22 13:45:09 +00:00
										 |  |  |          Encode and decode MIME base64 data} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-07-23 17:59:49 +00:00
										 |  |  | \declaremodule{standard}{base64} | 
					
						
							| 
									
										
										
										
											1999-02-22 13:45:09 +00:00
										 |  |  | \modulesynopsis{Encode and decode files using the MIME base64 data.} | 
					
						
							| 
									
										
										
										
											1998-07-23 17:59:49 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-02 16:24:29 +00:00
										 |  |  | \indexii{base64}{encoding} | 
					
						
							|  |  |  | \index{MIME!base64 encoding} | 
					
						
							| 
									
										
										
										
											1997-04-27 21:25:52 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-05-22 18:19:19 +00:00
										 |  |  | This module performs base64 encoding and decoding of arbitrary binary | 
					
						
							| 
									
										
										
										
											2001-07-14 02:50:55 +00:00
										 |  |  | strings into text strings that can be safely sent by email or included | 
					
						
							|  |  |  | as part of an HTTP POST request.  The | 
					
						
							| 
									
										
										
										
											2000-04-03 20:13:55 +00:00
										 |  |  | encoding scheme is defined in \rfc{1521} (\emph{MIME | 
					
						
							|  |  |  | (Multipurpose Internet Mail Extensions) Part One: Mechanisms for | 
					
						
							|  |  |  | Specifying and Describing the Format of Internet Message Bodies}, | 
					
						
							|  |  |  | section 5.2, ``Base64 Content-Transfer-Encoding'') and is used for | 
					
						
							|  |  |  | MIME email and various other Internet-related applications; it is not | 
					
						
							|  |  |  | the same as the output produced by the \program{uuencode} program. | 
					
						
							|  |  |  | For example, the string \code{'www.python.org'} is encoded as the | 
					
						
							|  |  |  | string \code{'d3d3LnB5dGhvbi5vcmc=\e n'}.   | 
					
						
							| 
									
										
										
										
											1997-04-27 21:25:52 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-11-30 05:53:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-01-07 03:47:10 +00:00
										 |  |  | \begin{funcdesc}{decode}{input, output} | 
					
						
							| 
									
										
										
										
											1997-04-27 21:25:52 +00:00
										 |  |  | Decode the contents of the \var{input} file and write the resulting | 
					
						
							|  |  |  | binary data to the \var{output} file. | 
					
						
							|  |  |  | \var{input} and \var{output} must either be file objects or objects that | 
					
						
							|  |  |  | mimic the file object interface. \var{input} will be read until | 
					
						
							|  |  |  | \code{\var{input}.read()} returns an empty string. | 
					
						
							|  |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{funcdesc}{decodestring}{s} | 
					
						
							|  |  |  | Decode the string \var{s}, which must contain one or more lines of | 
					
						
							| 
									
										
										
										
											1998-04-02 16:24:29 +00:00
										 |  |  | base64 encoded data, and return a string containing the resulting | 
					
						
							| 
									
										
										
										
											1997-04-27 21:25:52 +00:00
										 |  |  | binary data. | 
					
						
							|  |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-01-07 03:47:10 +00:00
										 |  |  | \begin{funcdesc}{encode}{input, output} | 
					
						
							| 
									
										
										
										
											1997-04-27 21:25:52 +00:00
										 |  |  | Encode the contents of the \var{input} file and write the resulting | 
					
						
							| 
									
										
										
										
											1998-04-02 16:24:29 +00:00
										 |  |  | base64 encoded data to the \var{output} file. | 
					
						
							| 
									
										
										
										
											1997-04-27 21:25:52 +00:00
										 |  |  | \var{input} and \var{output} must either be file objects or objects that | 
					
						
							|  |  |  | mimic the file object interface. \var{input} will be read until | 
					
						
							| 
									
										
										
										
											2001-09-28 16:01:46 +00:00
										 |  |  | \code{\var{input}.read()} returns an empty string.  If the last input | 
					
						
							|  |  |  | character is not a newline (\code{'\e n'}), a newline will be added to | 
					
						
							|  |  |  | the input data. | 
					
						
							| 
									
										
										
										
											1997-04-27 21:25:52 +00:00
										 |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{funcdesc}{encodestring}{s} | 
					
						
							|  |  |  | Encode the string \var{s}, which can contain arbitrary binary data, | 
					
						
							|  |  |  | and return a string containing one or more lines of | 
					
						
							| 
									
										
										
										
											2001-09-28 16:01:46 +00:00
										 |  |  | base64-encoded data.  If the last character of \var{s} is not a | 
					
						
							|  |  |  | newline (\code{'\e n'}), a newline will be added.  This causes | 
					
						
							|  |  |  | \code{encodestring('hello!')} to return the same value as | 
					
						
							|  |  |  | \code{encodestring('hello!\e n')}. | 
					
						
							| 
									
										
										
										
											1997-04-27 21:25:52 +00:00
										 |  |  | \end{funcdesc} | 
					
						
							| 
									
										
										
										
											1999-04-23 15:52:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{seealso} | 
					
						
							| 
									
										
										
										
											2000-10-18 17:43:06 +00:00
										 |  |  |   \seemodule{binascii}{Support module containing \ASCII{}-to-binary | 
					
						
							|  |  |  |                        and binary-to-\ASCII{} conversions.} | 
					
						
							| 
									
										
										
										
											2001-04-12 16:47:17 +00:00
										 |  |  |   \seerfc{1521}{MIME (Multipurpose Internet Mail Extensions) Part One: | 
					
						
							|  |  |  |           Mechanisms for Specifying and Describing the Format of | 
					
						
							|  |  |  |           Internet Message Bodies}{Section 5.2, ``Base64 | 
					
						
							|  |  |  |           Content-Transfer-Encoding,'' provides the definition of the | 
					
						
							|  |  |  |           base64 encoding.} | 
					
						
							| 
									
										
										
										
											1999-04-23 15:52:18 +00:00
										 |  |  | \end{seealso} |