python3 使用时如下:
#!/usr/bin/env python3 #coding=utf-8 from http.server import SimpleHTTPRequestHandler import socketserver import os,io,shutil import logging import cgi import sys import json log_path = './logs/run_server_logs.log' logging.basicConfig(level=logging.INFO,format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',datefmt='%a, %d %b %Y %H:%M:%S',filename=log_path) class MyHttpHandler(SimpleHTTPRequestHandler): def _set_headers(self): self.send_response(200) self.send_header('Content-type', 'text/html') self.end_headers() def send_datas(self,contents): #指定返回编码 enc = "UTF-8" content = contents.encode(enc) f = io.BytesIO() f.write(content) f.seek(0) self.send_response(200) self.send_header("Content-type", "text/html; charset=%s" % enc) self.send_header("Content-Length", str(len(contents))) self.end_headers() shutil.copyfileobj(f,self.wfile) def do_GET(self): logging.info("got get request "+str(self.path)) values = str(self.path) self.send_datas('这是get请求'+values) def do_POST(self): logging.info("got post!!") datasets = cgi.FieldStorage(fp = self.rfile,headers = self.headers,environ = {'REQUEST_METHOD': 'POST'}) logging.info(str(datasets)) id = datasets.getvalue('id') name = datasets.getvalue('name') msg = "name=="+str(name)+" id=="+str(id) flag = 1 results = {"status":flag,"msg":msg} self.send_datas(json.dumps(results)) def start_server(): server_host = '127.0.0.1' server_port = 8080 httpd = socketserver.TCPServer((server_host,server_port), MyHttpHandler) logging.info(' Start server success ... server_host:'+server_host+' server_port:'+str(server_port)) print('exe_server started on '+str(server_host)+' server_port:'+str(server_port)) httpd.serve_forever() if __name__ == "__main__": start_server()
python2使用时:
#!/usr/bin/env python #coding=utf-8 from SimpleHTTPServer import SimpleHTTPRequestHandler import SocketServer import os,io,shutil import logging import cgi import urlparse import sys reload(sys) sys.setdefaultencoding('utf-8') log_path = './logs/run_server_logs.log' logging.basicConfig(level=logging.INFO,format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',datefmt='%a, %d %b %Y %H:%M:%S',filename=log_path) class MyHttpHandler(SimpleHTTPRequestHandler): def _set_headers(self): self.send_response(200) self.send_header('Content-type', 'text/html') self.end_headers() def send_datas(self,contents): #指定返回编码 enc = "UTF-8" #contents = contents.encode(enc) f = io.BytesIO() f.write(contents) f.seek(0) self.send_response(200) self.send_header("Content-type", "text/html; charset=%s" % enc) self.send_header("Content-Length", str(len(contents))) self.end_headers() shutil.copyfileobj(f,self.wfile) def do_GET(self): logging.info("got get request "+str(self.path)) values = str(self.path) self.send_datas('get请求方式'+values) def do_POST(self): logging.info("got post!!") datasets = cgi.FieldStorage(fp = self.rfile,headers = self.headers,environ = {'REQUEST_METHOD': 'POST'}) logging.info(str(datasets)) id = datasets.getvalue('id') name = datasets.getvalue('name') msg = "name=="+str(name)+" id=="+str(id) flag = 1 results = {'status':flag,'msg':msg} self.send_datas(str(results)) def start_server(): server_host = '127.0.0.1' server_port = 8080 httpd = SocketServer.TCPServer((server_host,server_port), MyHttpHandler) logging.info(' Start server success ... server_host:'+server_host+' server_port:'+str(server_port)) print('exe_server started on '+str(server_host)+' server_port:'+str(server_port)) httpd.serve_forever() if __name__ == "__main__": start_server()
python3与python2中SimpleHTTPRequestHandler导入方式不同,3是 from http.server import SimpleHTTPRequestHandler , 2是 from SimpleHTTPServer import SimpleHTTPRequestHandler ;
另外serversocket也不一样3是 import socketserver httpd = socketserver.TCPServer((server_host,server_port), MyHttpHandler) ,2是 import SocketServer httpd = SocketServer.TCPServer((server_host,server_port), MyHttpHandler)
其他变化可自行设置.......