Итак, у меня есть обработчик Go http Go, который хранит некоторый контент POST в хранилище данных и извлекает другую информацию в ответ. На внутреннем сервере я использую:
func handleMessageQueue(w http.ResponseWriter, r *http.Request) {
w.Header().Set("Access-Control-Allow-Origin", "*")
if r.Method == "POST" {
c := appengine.NewContext(r)
body, _ := ioutil.ReadAll(r.Body)
auth := string(body[:])
r.Body.Close()
q := datastore.NewQuery("Message").Order("-Date")
var msg []Message
key, err := q.GetAll(c, &msg)
if err != nil {
c.Errorf("fetching msg: %v", err)
return
}
w.Header().Set("Content-Type", "application/json")
jsonMsg, err := json.Marshal(msg)
msgstr := string(jsonMsg)
fmt.Fprint(w, msgstr)
return
}
}
В моем приложении OS firefox я использую:
var message = "content";
request = new XMLHttpRequest();
request.open('POST', 'http://localhost:8080/msgs', true);
request.onload = function () {
if (request.status >= 200 && request.status < 400) {
// Success!
data = JSON.parse(request.responseText);
console.log(data);
} else {
// We reached our target server, but it returned an error
console.log("server error");
}
};
request.onerror = function () {
// There was a connection error of some sort
console.log("connection error");
};
request.send(message);
Входящая часть все работает и так далее. Однако мой ответ блокируется. Предоставляя мне следующее сообщение:
Cross-Origin Request Blocked: The Same Origin Policy disallows reading the remote resource at http://localhost:8080/msgs. This can be fixed by moving the resource to the same domain or enabling CORS.
Я пробовал много других вещей, но я никак не могу получить ответ от сервера. Однако, когда я изменяю свой метод Go POST в GET и просматриваю страницу через браузер, я получаю данные, которые мне так жаль. Я не могу решить, какая сторона идет не так, и почему: возможно, Go не должен блокировать подобные запросы, но также может быть, что мой javascript является незаконным.