#!/usr/bin/env python3 # HTTPS server test application. # # You can generate certificate file like this: # openssl req -x509 -newkey rsa:2048 -keyout https-server.pem \ # -out https-server.pem -days 10000 -nodes \ # -subj '/CN=localhost' # # To see the contents of the certificate do this: # openssl x509 -in https-server.pem -text -noout # # To add the cert into your application do this: # openssl x509 -in https-server.pem -C -noout # import socket from http.server import HTTPServer, BaseHTTPRequestHandler import ssl import sys PORT = 4443 class HTTPServerV6(HTTPServer): address_family = socket.AF_INET6 class RequestHandler(BaseHTTPRequestHandler): length = 0 def _set_headers(self): self.send_response(200) self.send_header('Content-Type', 'text/html') self.send_header('Content-Length', str(self.length)) self.end_headers() def do_POST(self): payload = "
Done
" self.length = len(payload) self._set_headers() self.wfile.write(payload) def do_GET(self): payload = "Done
" self.length = len(payload) self._set_headers() self.wfile.write(payload.encode()) def main(address): if ':' in address: httpd = HTTPServerV6((address, PORT), RequestHandler) else: httpd = HTTPServer((address, PORT), RequestHandler) print("Serving at port", PORT) httpd.socket = ssl.wrap_socket (httpd.socket, certfile='/net-tools/https-server.pem', server_side=True) httpd.serve_forever() if __name__ == '__main__': if len(sys.argv) > 1: main(sys.argv[1]) else: main('::')