Я использую axios, чтобы сделать запрос от внешнего интерфейса VueJS.CORS-запросы выполняют два вызова, первый - OPTIONS
, второй с запрошенным, поэтому POST
в моем случае.
Он отлично работает на Chrome, но если я использую Safari или Firefox, у меня есть только OPTIONS
запрос.Они не выполняют запрос POST
.
PHP (я использую Phalcon PHP):
public function JSONBuilderCORS($data, $code) {
$response = new Response();
$message = $this->getResponseDescription($code);
if ($this->request->getServer('HTTP_ORIGIN')) {
$response->setHeader('Access-Control-Allow-Origin', '*');
$response->setHeader('Access-Control-Allow-Credentials', true);
$response->setHeader('Access-Control-Max-Age', 86400);
}
if ($this->request->isOptions()) {
if ($this->request->getServer('HTTP_ACCESS_CONTROL_REQUEST_METHOD')) {
$response->setHeader('Access-Control-Allow-Methods', 'GET, POST, PATCH, PUT, DELETE, OPTIONS');
}
if ($this->request->getServer('HTTP_ACCESS_CONTROL_REQUEST_HEADERS')) {
$response->setHeader('Access-Control-Allow-Headers', '*');
}
$response->setStatusCode($code, $message);
$response->setContent($data);
return $response;
}
$response->setHeader('Content-Type', 'application/json');
$response->setStatusCode($code, $message);
$response->setJsonContent($data);
return $response;
}
VueJS:
let config = {
headers: {
'Access-Control-Allow-Origin' : '*',
'Content-Type': 'application/x-www-form-urlencoded'
}
};
axios.post('http://example.com/charge', {
firstname: this.firstname,
lastname: this.lastname,
amount: this.finalAmount * 100,
source: result.token.id
},config)
.then((response) => {
this.loading = false;
this.paid = true;
this.snackbarSuccess = true;
})
.catch((error) => {
this.loading = false;
this.snackbarError = true;
});
Заголовки ответов Firefox:
Access-Control-Allow-Credentials
1
Access-Control-Allow-Headers
*
Access-Control-Allow-Methods
GET, POST, PATCH, PUT, DELETE, OPTIONS
Access-Control-Allow-Origin
*
Access-Control-Max-Age
86400
Connection
keep-alive
Content-Length
2
Content-Type
text/html; charset=UTF-8
Date
Wed, 30 Jan 2019 16:40:13 GMT
Server
nginx
Status
200 OK
Request headers (515 B)
Accept
text/html,application/xhtml+xm…ml;q=0.9,image/webp,*/*;q=0.8
Accept-Encoding
gzip, deflate
Accept-Language
en-US,en;q=0.5
Access-Control-Request-Headers
access-control-allow-origin
Access-Control-Request-Method
POST
Connection
keep-alive
Host
example.com
Origin
http://localhost:8080
Referer
http://localhost:8080/payment
User-Agent
Mozilla/5.0 (Macintosh; Intel …) Gecko/20100101 Firefox/65.0
Я не понимаю, почему он не работает в другом браузере, можешь мне помочь?