I'm using SimpleHTTPServer
to test some webpages I'm working on. It works great, however I need to do some cross-domain requests. That requires setting a Access-Control-Allow-Origin
header with the domains the page is allowed to access.
Is there an easy way to set a header with SimpleHTTPServer and serve the original content? The header would be the same on each request.
While this is an older answer, its the first result in google...
Basically what @iMon0 suggested..Seems correct?..Example of
doPOST
By doing this, the flow feels correct..
1: You get a request
2: You apply the headers and response type you want
3: You post back the data you want, be this what or how ever you want.,
The above example is working fine for me and can be extended further, its just a bare bone JSON post server. So i'll leave this here on SOF incase someone needs it or i myself come back in a few months for it.
This does produce a valid JSON file with only the sTest object, Same as a PHP generated page/file.
I'd say there's no simple way of doing it, where simple means "just add 1-2 lines that will write the additional header and keep the existing functionality". So, the best solution would be to subclass the
SimpleHTTPRequestHandler
class and re-implement the functionality, with the addition of the new header.The problem behind why there is no simple way of doing this can be observed by looking at the implementation of the
SimpleHTTPRequestHandler
class in the Python library: http://hg.python.org/cpython/file/19c74cadea95/Lib/http/server.py#l654Notice the
send_head()
method, particularly the lines at the end of the method which send the response headers. Notice the invocation of theend_headers()
method. This method writes the headers to the output, together with a blank line which signals the end of all headers and the start of the response body: http://docs.python.org/py3k/library/http.server.html#http.server.BaseHTTPRequestHandler.end_headersTherefore, it would not be possible to subclass the
SimpleHTTPRequestHandler
handler, invoke the super-classdo_GET()
method, and then just add another header -- because the sending of the headers has already finished when the call to the super-classdo_GET()
method returns. And it has to work like this because thedo_GET()
method has to send the body (the file that is requested), and to send the body - it has to finalize sending the headers.So, again, I think you're stuck with sub-classing the
SimpleHTTPRequestHandler
class, implementing it exactly as the code in the library (just copy-paste it?), and add another header before the call to theend_headers()
method insend_head()
:This is a bit of a hack because it changes
end_headers()
behavior, but I think it's slightly better than copying and pasting the entireSimpleHTTPServer.py
file.My approach overrides
end_headers()
in a subclass and in it callssend_my_headers()
followed by calling the superclass'send_headers()
.It's not 1 - 2 lines either, less than 20 though; mostly boilerplate.