【发布时间】:2016-02-15 04:30:46
【问题描述】:
我想在 Angular 2 中发出以下 POST 请求。
http://gearman.local.eviry.com/info
正文如下
{"gearman_servers" :[{
"name" : "server 1",
"addr" : "192.168.1.115"
},
{
"name" : "Server 2",
"addr" : "192.0.1.126"
}
]}
我已确保这在 Angular 2 之外有效。(使用 POSTMAN) 我还确保启用了 CORS。
以下是我的角度代码
var url = 'http://gearman.local.eviry.com' +
'/info';
var GEARMAN_DATA = {"gearman_servers" :[{
"name" : "server 1",
"addr" : "192.168.1.115"
},
{
"name" : "Server 2",
"addr" : "192.0.1.126"
}]};
let body = JSON.stringify(GEARMAN_DATA);
let headers = new Headers({ 'Content-Type': 'application/json' });
let options = new RequestOptions({ headers: headers });
this.http.post(url, body, options)
.map(res => res.json())
.subscribe(
data => {console.log(data);},
err => this.logError(err),
() => console.log('Fetching complete for Server Metrics')
);
logError(err:Response){
console.log("some error");
console.log(err);
}
但是,这样做会给我一个错误
XMLHttpRequest cannot load http://gearman.local.eviry.com/info. Invalid HTTP status code 405
另外,当我在 logError 函数中打印出错误时,我得到以下信息:
很难弄清楚请求有什么问题。
Request Headers如图所示
Accept:*/*
Accept-Encoding:gzip, deflate, sdch
Accept-Language:en-US,en;q=0.8
Access-Control-Request-Headers:content-type
Access-Control-Request-Method:POST
Cache-Control:no-cache
Connection:keep-alive
Host:gearman.local.eviry.com
Origin:http://evil.com/
Pragma:no-cache
Referer:http://localhost:3000/gearman-ui/job-queue
User-Agent:Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/44.0.2403.155 Safari/537.36
X-FirePHP:0.4.4
X-FirePHP-Version:0.4.4
X-Wf-Max-Combined-Size:262144
响应头如图所示
Allow:POST
Cache-Control:no-cache
Connection:Keep-Alive
Content-Length:4519
Content-Type:text/html; charset=UTF-8
Date:Mon, 15 Feb 2016 08:32:54 GMT
Keep-Alive:timeout=5, max=100
Server:Apache/2.2.24 (Unix) mod_ssl/2.2.24 OpenSSL/1.0.1e-fips
如果有人使用POSTMAN,我有以下代码有效。我必须使用 angular 来实现相同的功能。(请注意,您将无法访问 http://gearman.local.eviry.com)
【问题讨论】:
-
您能显示您的请求和响应标头吗? (开发工具>网络>[选择您的请求]>标题)
-
添加了请求标头
-
HTTP post看这里...stackoverflow.com/a/34823818/5043867 和stackoverflow.com/a/34758630/5043867
标签: angularjs rest http-post angular