Angular http 返回状态 0,但我预计是 404
Angular http returning status 0, but I expect 404
我正在向具有以下路由的服务器发出请求:
app.use('/401', (req, res) => res.status(401).end());
app.use('/403', (req, res) => res.status(403).end());
app.use('/404', (req, res) => res.status(404).end());
app.use('/500', (req, res) => res.status(500).end());
app.use('/502', (req, res) => res.status(502).end());
app.use('/503', (req, res) => res.status(503).end());
app.use('/504', (req, res) => res.status(504).end());
当我用 Angular (/404
, {}
) 发出请求时:
public async post(path: string, data: object): Promise<Response> {
try {
return await this.http.post(path, data).toPromise();
} catch (err) {
console.log('err', err);
throw err;
}
}
我得到:
ok: false
status: 0
statusText: ""
type: 3
在 Chrome 控制台中,我看到请求是用 OPTIONS
发出的,它确实 return 404:
Request URL: http://localhost:3000/404/
Request Method: OPTIONS
Status Code: 404 Not Found
它去哪儿了?我怎样才能得到真正的错误代码?
我读到这可能是 CORS 问题...我的应用程序在 4200 上,我的服务在 3000 上。在我的服务中,我排在最前面(在其他任何事情之前):
app.use(function(req, res, next) {
res.setHeader("Access-Control-Allow-Origin", "*");
res.setHeader("Access-Control-Allow-Credentials", "true");
res.setHeader("Access-Control-Allow-Methods", "*");
res.setHeader("Access-Control-Allow-Headers", "*");
next();
});
我不认为这是 COR 的问题...
但我不知道,会不会是?
我不应该得到状态为 404
的 err
吗?
显然 OPTIONS
永远不会 return 成为 404
,因为它会导致此错误:
Response for preflight has invalid HTTP status code 404
如果是 OPTIONS
请求,我将 headers 更改为 end
请求,否则继续:
const headers = (req, res, next) => {
res.setHeader("Cache-Control", "no-cache");
res.setHeader("Access-Control-Allow-Origin", "*");
res.setHeader("Access-Control-Allow-Credentials", "true");
res.setHeader("Access-Control-Allow-Methods", "GET, HEAD, POST, PUT, PATCH, DELETE, OPTIONS");
res.setHeader("Access-Control-Allow-Headers", "Content-Type, Authorization, Accept");
};
app.use((req, res, next) => {
console.log(req.method);
headers(req, res, next);
if (req.method === 'OPTIONS') {
return res.end();
}
next();
});
然后在 Angular 应用程序上请求 return 正确的数据:
ok: false
status: 404
statusText: "Not Found"
type: 2
我正在向具有以下路由的服务器发出请求:
app.use('/401', (req, res) => res.status(401).end());
app.use('/403', (req, res) => res.status(403).end());
app.use('/404', (req, res) => res.status(404).end());
app.use('/500', (req, res) => res.status(500).end());
app.use('/502', (req, res) => res.status(502).end());
app.use('/503', (req, res) => res.status(503).end());
app.use('/504', (req, res) => res.status(504).end());
当我用 Angular (/404
, {}
) 发出请求时:
public async post(path: string, data: object): Promise<Response> {
try {
return await this.http.post(path, data).toPromise();
} catch (err) {
console.log('err', err);
throw err;
}
}
我得到:
ok: false
status: 0
statusText: ""
type: 3
在 Chrome 控制台中,我看到请求是用 OPTIONS
发出的,它确实 return 404:
Request URL: http://localhost:3000/404/
Request Method: OPTIONS
Status Code: 404 Not Found
它去哪儿了?我怎样才能得到真正的错误代码?
我读到这可能是 CORS 问题...我的应用程序在 4200 上,我的服务在 3000 上。在我的服务中,我排在最前面(在其他任何事情之前):
app.use(function(req, res, next) {
res.setHeader("Access-Control-Allow-Origin", "*");
res.setHeader("Access-Control-Allow-Credentials", "true");
res.setHeader("Access-Control-Allow-Methods", "*");
res.setHeader("Access-Control-Allow-Headers", "*");
next();
});
我不认为这是 COR 的问题...
但我不知道,会不会是?
我不应该得到状态为 404
的 err
吗?
显然 OPTIONS
永远不会 return 成为 404
,因为它会导致此错误:
Response for preflight has invalid HTTP status code 404
如果是 OPTIONS
请求,我将 headers 更改为 end
请求,否则继续:
const headers = (req, res, next) => {
res.setHeader("Cache-Control", "no-cache");
res.setHeader("Access-Control-Allow-Origin", "*");
res.setHeader("Access-Control-Allow-Credentials", "true");
res.setHeader("Access-Control-Allow-Methods", "GET, HEAD, POST, PUT, PATCH, DELETE, OPTIONS");
res.setHeader("Access-Control-Allow-Headers", "Content-Type, Authorization, Accept");
};
app.use((req, res, next) => {
console.log(req.method);
headers(req, res, next);
if (req.method === 'OPTIONS') {
return res.end();
}
next();
});
然后在 Angular 应用程序上请求 return 正确的数据:
ok: false
status: 404
statusText: "Not Found"
type: 2