Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xjbieke
axios
提交
4fbf0846
A
axios
项目概览
xjbieke
/
axios
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
A
axios
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
4fbf0846
编写于
3月 08, 2018
作者:
N
Nick Uraltsev
提交者:
GitHub
3月 08, 2018
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #1040 from pbarbiero/pbarbiero/improved-timeout-handling
Decorate resolve and reject to clear timeout in all cases
上级
b14cdd84
fa3c6d22
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
11 addition
and
7 deletion
+11
-7
lib/adapters/http.js
lib/adapters/http.js
+11
-7
未找到文件。
lib/adapters/http.js
浏览文件 @
4fbf0846
...
...
@@ -15,10 +15,18 @@ var enhanceError = require('../core/enhanceError');
/*eslint consistent-return:0*/
module
.
exports
=
function
httpAdapter
(
config
)
{
return
new
Promise
(
function
dispatchHttpRequest
(
resolve
,
reject
)
{
return
new
Promise
(
function
dispatchHttpRequest
(
resolvePromise
,
rejectPromise
)
{
var
timer
;
var
resolve
=
function
resolve
(
value
)
{
clearTimeout
(
timer
);
resolvePromise
(
value
);
};
var
reject
=
function
reject
(
value
)
{
clearTimeout
(
timer
);
rejectPromise
(
value
);
};
var
data
=
config
.
data
;
var
headers
=
config
.
headers
;
var
timer
;
// Set User-Agent (required by some servers)
// Only set header if it hasn't been set in config
...
...
@@ -141,10 +149,6 @@ module.exports = function httpAdapter(config) {
var
req
=
transport
.
request
(
options
,
function
handleResponse
(
res
)
{
if
(
req
.
aborted
)
return
;
// Response has been received so kill timer that handles request timeout
clearTimeout
(
timer
);
timer
=
null
;
// uncompress the response body transparently if required
var
stream
=
res
;
switch
(
res
.
headers
[
'
content-encoding
'
])
{
...
...
@@ -210,7 +214,7 @@ module.exports = function httpAdapter(config) {
});
// Handle request timeout
if
(
config
.
timeout
&&
!
timer
)
{
if
(
config
.
timeout
)
{
timer
=
setTimeout
(
function
handleRequestTimeout
()
{
req
.
abort
();
reject
(
createError
(
'
timeout of
'
+
config
.
timeout
+
'
ms exceeded
'
,
config
,
'
ECONNABORTED
'
,
req
));
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录