你的python送你的文件传输助手
python2或者3都有(如果兄弟姐妹们还在用python2,建议转到py3吧,修改代码加__future__其实也不是长久之计啦)
鉴于我是python3.6+ubuntu18.04,
输入
python3 -m http.server
打开你的手机浏览器,网址栏输入
你的电脑ip:8000
例如:192.168.***.***:8000
监听你的电脑的8000号端口就行,这样你就可以看到你的电脑里面的文件了。
方便,还挺好玩的…
注意哦,你的手机和电脑要在同一个局域网下面,也就是说要连一个网。
不过就是只能看,不能上传,也有升级的空间。
github上看到过一个不错的脚本,本来是准备自己实现的来着。/xk/xk/xk
分享一下吧。
#!/usr/bin/env python3"""Simple HTTP Server With Upload.
This module builds on http.server by implementing the standard GET
and HEAD requests in a fairly straightforward manner.
see: https://gist.github.com/UniIsland/3346170
"""__version__ = "0.1"
__all__ = ["SimpleHTTPRequestHandler"]
__author__ = "bones7456"
__home_page__ = "https://gist.github.com/UniIsland/3346170"import os
import posixpath
import http.server
import socketserver
import urllib.request, urllib.parse, urllib.error
import html
import shutil
import mimetypes
import re
import argparse
import base64from io import BytesIOclass SimpleHTTPRequestHandler(http.server.BaseHTTPRequestHandler):"""Simple HTTP request handler with GET/HEAD/POST commands.This serves files from the current directory and any of itssubdirectories. The MIME type for files is determined bycalling the .guess_type() method. And can reveive file uploadedby client.The GET/HEAD/POST requests are identical except that the HEADrequest omits the actual contents of the file."""server_version = "SimpleHTTPWithUpload/" + __version__def do_GET(self):"""Serve a GET request."""f = self.send_head()if f:self.copyfile(f, self.wfile)f.close()def do_HEAD(self):"""Serve a HEAD request."""f = self.send_head()if f:f.close()def do_POST(self):"""Serve a POST request."""r, info = self.deal_post_data()print((r, info, "by: ", self.client_address))f = BytesIO()f.write(b'')f.write(b"\nUpload Result Page \n")f.write(b"\nUpload Result Page
\n")f.write(b"
\n")if r:f.write(b"Success:")else:f.write(b"Failed:")f.write(info.encode())f.write(("
Parent Directory
\n')for name in list:dirimage = ''fullname = os.path.join(path, name)displayname = linkname = name# Append / for directories or @ for symbolic linksif os.path.isdir(fullname):dirimage = ''displayname = name + "/"linkname = name + "/"if os.path.islink(fullname):dirimage = ''displayname = name + "@"if name.endswith(('.bmp','.gif','.jpg','.png')):dirimage = nameif name.endswith(('.avi','.mpg')):dirimage = ''if name.endswith(('.idx','.srt','.sub')):dirimage = ''if name.endswith('.iso'):dirimage = ''# Note: a link to a directory displays with @ and links with /f.write(('
%s
\n'% (urllib.parse.quote(linkname), dirimage , html.escape(displayname))).encode())f.write(b"
\n\n\n")length = f.tell()f.seek(0)self.send_response(200)self.send_header("Content-type", "text/html")self.send_header("Content-Length", str(length))self.end_headers()return fdef translate_path(self, path):"""Translate a /-separated PATH to the local filename syntax.Components that mean special things to the local file system(e.g. drive or directory names) are ignored. (XXX They shouldprobably be diagnosed.)"""# abandon query parameterspath = path.split('?',1)[0]path = path.split('#',1)[0]path = posixpath.normpath(urllib.parse.unquote(path))words = path.split('/')words = [_f for _f in words if _f]path = os.getcwd()for word in words:drive, word = os.path.splitdrive(word)head, word = os.path.split(word)if word in (os.curdir, os.pardir): continuepath = os.path.join(path, word)return pathdef copyfile(self, source, outputfile):"""Copy all data between two file objects.The SOURCE argument is a file object open for reading(or anything with a read() method) and the DESTINATIONargument is a file object open for writing (oranything with a write() method).The only reason for overriding this would be to changethe block size or perhaps to replace newlines by CRLF-- note however that this the default server uses thisto copy binary data as well."""shutil.copyfileobj(source, outputfile)def guess_type(self, path):"""Guess the type of a file.Argument is a PATH (a filename).Return value is a string of the form type/subtype,usable for a MIME Content-type header.The default implementation looks the file's extensionup in the table self.extensions_map, using application/octet-streamas a default; however it would be permissible (ifslow) to look inside the data to make a better guess."""base, ext = posixpath.splitext(path)if ext in self.extensions_map:return self.extensions_map[ext]ext = ext.lower()if ext in self.extensions_map:return self.extensions_map[ext]else:return self.extensions_map['']if not mimetypes.inited:mimetypes.init() # try to read system mime.typesextensions_map = mimetypes.types_map.copy()extensions_map.update({'': 'application/octet-stream', # Default'.py': 'text/plain','.c': 'text/plain','.h': 'text/plain',})parser = argparse.ArgumentParser()
parser.add_argument('--bind', '-b', default='', metavar='ADDRESS',help='Specify alternate bind address ''[default: all interfaces]')
parser.add_argument('port', action='store',default=8000, type=int,nargs='?',help='Specify alternate port [default: 8000]')
args = parser.parse_args()PORT = args.port
BIND = args.bind
HOST = BINDif HOST == '':HOST = 'localhost'Handler = SimpleHTTPRequestHandlerwith socketserver.TCPServer((BIND, PORT), Handler) as httpd:serve_message = "Serving HTTP on {host} port {port} (http://{host}:{port}/) ..."print(serve_message.format(host=HOST, port=PORT))httpd.serve_forever()
我自己之前是经常碰见需要修改代码这种事儿(说实话心态很崩),别怕什么的,这个可以直接用,有空的时候也可以看看写了啥,挺受用的。
当然了,还是一个网下面监听电脑ip的8000号端口(这个端口是python设定的,当然其实也不用太在意这个啦)
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
