所以我要做的是允许用户在他们的网站上嵌入图像,然后该图像会被iframe内部的按钮自动替换。原因是让用户可以轻松避免在不允许使用的网络上使用js或其他代码。
这在PHP的apache中是可行的,但是在python中这样做的方式对我来说并不是特别明显。
原始htaccess:
Redirect /embed.jpg http://somesite.com/embed.php
但是在python中,它并没有真正起作用(这个例子不起作用)。
server.py:
#!/usr/bin/env python
import BaseHTTPServer
import getopt
import socket
import sys
ADDR = ["", 8080]
def usage(f = sys.stdout):
print >> f, "Usage: %s [ADDRESS [PORT]]" % sys.argv[0]
class Handler(BaseHTTPServer.BaseHTTPRequestHandler):
def do_GET(self):
if self.path == "/":
self.send_response(200)
self.send_header("Content-type", "text/html; charset=utf-8")
self.end_headers()
print >> self.wfile, """\
<!DOCTYPE html>
<body bgcolor=dodgerblue>
<img src="x.png" width=200 height=200>
</body>
"""
return
if self.path == "/x.png":
self.send_response(302)
self.send_header("Content-type", "image/png")
self.send_header("Location", "x.html")
self.end_headers()
return
if self.path == "/x.html":
self.send_response(200)
self.send_header("Content-type", "text/html; charset=utf-8")
self.end_headers()
print >> self.wfile, """\
<!DOCTYPE html>
<body bgcolor=slateblue>
Inner HTML.
</body>
"""
self.send_response(404)
self.send_header("Content-type", "text/html; charset=utf-8")
self.end_headers()
print >> self.wfile, """\
<!DOCTYPE html>
Not found.
"""
class Server(BaseHTTPServer.HTTPServer):
allow_reuse_address = True
opts, args = getopt.gnu_getopt(sys.argv[1:], "h", ["help"])
for o, a in opts:
if o == "-h" or o == "--help":
usage()
sys.exit(0)
if len(args) >= 1:
ADDR[0] = args[0]
if len(args) >= 2:
ADDR[1] = args[1]
if len(args) >= 3:
usage(sys.stderr)
os.exit(1)
server = Server(tuple(ADDR), Handler)
print "Listening on %s:%d." % (server.server_name, server.server_port)
server.serve_forever()
答案 0 :(得分:0)
我可以通过该代码看到两个问题...
首先,<img src="x.png" width=200 height=200>
意味着浏览器应该返回图像数据,而是将它们重定向到另一个返回HTML数据的URL。
其次,我认为你错过return
中的if
- 直接在该行之前阻止...
self.send_response(404)
我不认为可以用<img>
标记替换<iframe>
标记,而无需在JavaScript中修改DOM。