如何在python中将请求转发到其他url

2024-04-27 17:00:44 发布

您现在位置:Python中文网/ 问答频道 /正文

我一直在寻找语法来重定向一个特殊的url到一个远程服务器来做一些XSS测试。有什么想法吗?

import SimpleHTTPServer
import SocketServer

class myHandler(SimpleHTTPServer.SimpleHTTPRequestHandler):
    def do_GET(self):
        print self.path 
        if self.path == '/analog':
-------------------->return "http://12b.dk/analog"???
        return SimpleHTTPServer.SimpleHTTPRequestHandler.do_GET(self)

theport = 1234
Handler = myHandler
pywebserver = SocketServer.TCPServer(("", theport), Handler)

print "Python based web server. Serving at port", theport
pywebserver.serve_forever()

Tags: pathimportselfgetreturndohandlerprint
3条回答

这是一段完整的代码,用于重定向、保存此文件并将其作为python程序运行。要终止,请按ctrl+c

import SimpleHTTPServer
import SocketServer
class myHandler(SimpleHTTPServer.SimpleHTTPRequestHandler):
   def do_GET(self):
       print self.path
       self.send_response(301)
       new_path = '%s%s'%('http://newserver.com', self.path)
       self.send_header('Location', new_path)
       self.end_headers()

PORT = 8000
handler = SocketServer.TCPServer(("", PORT), myHandler)
print "serving at port 8000"
handler.serve_forever()

Python3

python3中,它的做法与其他答案非常相似,但差异足以证明演示的合理性。

这是一个脚本,它只监听作为参数1传递的端口,并发送302(“Found”aka Temporary)重定向到作为参数2传递的URL。(它有一条使用信息。)

#!/usr/bin/env python3

import sys
from http.server import HTTPServer, BaseHTTPRequestHandler

if len(sys.argv)-1 != 2:
    print("""
Usage: {} <port_number> <url>
    """.format(sys.argv[0]))
    sys.exit()

class Redirect(BaseHTTPRequestHandler):
   def do_GET(self):
       self.send_response(302)
       self.send_header('Location', sys.argv[2])
       self.end_headers()

HTTPServer(("", int(sys.argv[1])), Redirect).serve_forever()

你这样称呼它:

sudo ./redirect.py 80 http://jenkins.example.com:8080/

这个例子应该足够让你写出你所需要的函数。

对于重定向,您必须返回一个代码301,外加一个Location头。或许你可以尝试一下:

class myHandler(SimpleHTTPServer.SimpleHTTPRequestHandler):
   def do_GET(self):
       self.send_response(301)
       self.send_header('Location','http://www.example.com')
       self.end_headers()

相关问题 更多 >