Frage

Mein JSON-RPC-Client (Browser mit Dojo JSON-RPC) stellt eine JSON-RPC-Anfrage (dojo.callremote) an meinen JSON-RPC-Server auf myserver.com/12345 (Python 2.5, simplejsonrpcserver).

Der Server erhält dann eine HTTP -Anforderung mit Header "Optionen / HTTP / 1.1", die standardmäßig nicht verarbeitet werden kann. Deshalb habe ich einen benutzerdefinierten Handler für diese Anfrage geschrieben.

In dem Anforderungs -Header aus dem Browser heißt es:

OPTIONS / HTTP/1.1
Host: myserver:12345
User-Agent: Mozilla/5.0 (X11; U; Linux x86_64; en-US; rv:1.9.1.8) Gecko/20100214 Linux Mint/8 (Helena) Firefox/3.5.8 (.NET CLR 3.5.30729)
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-us,en;q=0.7,de;q=0.3
Accept-Encoding: gzip,deflate
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
Keep-Alive: 300
Origin: http://myserver.com
Access-Control-Request-Method: POST
Access-Control-Request-Headers: x-requested-with

Und die Antwort, die ich sende, sieht so aus:

HTTP/1.0 200 OK
Server: BaseHTTP/0.3 Python/2.5
Date: Mon, 05 Apr 2010 18:58:34 GMT
Access-Control-Allow-Method: POST
Access-Control-Allow-Headers: POST
Allow: POST
Content-Type: application/json-rpc
Content-length: 0

Aber im Browser erhalte ich den folgenden Fehler:

Fehler: Das Laden kann nicht geladen werden http://myserver.com:12345 Status: 0

Ich habe überprüft, ob der JSON-Service vom Netz erreichbar ist.

Nun ist die Frage: Was erwartet der Browser (z. B. Firefox) die Reaktionshörer sagen? Oder liegt das Problem woanders?

War es hilfreich?

Lösung

Siehe das CORS -Spezifikation.

(Übrigens; es gibt eine Header -Registrierung für HTTP, siehe http://www.iana.org/asssignments/message-headers/prov-headers.html und http://www.iana.org/asssignments/message-headers/perm-headers.html, was Sie auf die richtige Spezifikation gerichtet hätte).

Andere Tipps

Fügen Sie Code hinzu und versuchen Sie es, es funktioniert gut für mich:

class CGIHTTPRequestHandler(SimpleHTTPServer.SimpleHTTPRequestHandler):
...
...
    def do_OPTIONS(self):
        self.send_response(200, "ok")
        self.send_header('Access-Control-Allow-Origin', self.headers.dict['origin'])
        self.send_header('Access-Control-Allow-Methods', 'POST, OPTIONS')

Überprüfen Sie meinen Code. Es funktioniert für Client -JavaScript -Code im Chrome -Browser.

class MyHandler(BaseHTTPRequestHandler):
    def do_OPTIONS(self):           
        self.send_response(200, "ok")       
        self.send_header('Access-Control-Allow-Origin', '*')                
        self.send_header('Access-Control-Allow-Methods', 'GET, POST, OPTIONS')
        self.send_header("Access-Control-Allow-Headers", "X-Requested-With")        

    def do_GET(self):           
        self.send_response(200)
        self.send_header('Access-Control-Allow-Origin', '*')
        self.send_header('Content-type',    'text/html')                                    
        self.end_headers()              
        self.wfile.write("<html><body>Hello world!</body></html>")
        self.connection.shutdown(1) 
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top