Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
weixin_38335589
uni-app
提交
b793e752
U
uni-app
项目概览
weixin_38335589
/
uni-app
与 Fork 源项目一致
Fork自
DCloud / uni-app
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
uni-app
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
b793e752
编写于
10月 30, 2020
作者:
W
wzb
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix:cookie sometime parse error and typo
上级
4a8fc084
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
183 addition
and
183 deletion
+183
-183
src/platforms/app-plus/service/api/network/request.js
src/platforms/app-plus/service/api/network/request.js
+183
-183
未找到文件。
src/platforms/app-plus/service/api/network/request.js
浏览文件 @
b793e752
import
{
hasOwn
}
from
'
uni-shared
'
import
{
publish
,
requireNativePlugin
,
base64ToArrayBuffer
}
from
'
../../bridge
'
let
requestTaskId
=
0
const
requestTasks
=
{}
const
publishStateChange
=
res
=>
{
publish
(
'
onRequestTaskStateChange
'
,
res
)
delete
requestTasks
[
requestTaskId
]
}
const
cookiesP
rase
=
header
=>
{
let
cookiesStr
=
header
[
'
Set-Cookie
'
]
||
header
[
'
set-cookie
'
]
let
cookiesArr
=
[]
if
(
!
cookiesStr
)
{
return
[]
}
if
(
cookiesStr
[
0
]
===
'
[
'
&&
cookiesStr
[
cookiesStr
.
length
-
1
]
===
'
]
'
)
{
cookiesStr
=
cookiesStr
.
slice
(
1
,
-
1
)
}
const
handleCookiesArr
=
cookiesStr
.
split
(
'
;
'
)
for
(
let
i
=
0
;
i
<
handleCookiesArr
.
length
;
i
++
)
{
if
(
handleCookiesArr
[
i
].
indexOf
(
'
Expires=
'
)
!==
-
1
)
{
cookiesArr
.
push
(
handleCookiesArr
[
i
].
replace
(
'
,
'
,
''
))
}
else
{
cookiesArr
.
push
(
handleCookiesArr
[
i
])
}
}
cookiesArr
=
cookiesArr
.
join
(
'
;
'
).
split
(
'
,
'
)
return
cookiesArr
}
export
function
createRequestTaskById
(
requestTaskId
,
{
url
,
data
,
header
,
method
=
'
GET
'
,
responseType
,
sslVerify
=
true
,
firstIpv4
=
false
}
=
{})
{
const
stream
=
requireNativePlugin
(
'
stream
'
)
const
headers
=
{}
let
abortTimeout
let
aborted
let
hasContentType
=
false
for
(
const
name
in
header
)
{
if
(
!
hasContentType
&&
name
.
toLowerCase
()
===
'
content-type
'
)
{
hasContentType
=
true
headers
[
'
Content-Type
'
]
=
header
[
name
]
// TODO 需要重构
if
(
method
!==
'
GET
'
&&
header
[
name
].
indexOf
(
'
application/x-www-form-urlencoded
'
)
===
0
&&
typeof
data
!==
'
string
'
&&
!
(
data
instanceof
ArrayBuffer
))
{
const
bodyArray
=
[]
for
(
const
key
in
data
)
{
if
(
hasOwn
(
data
,
key
))
{
bodyArray
.
push
(
encodeURIComponent
(
key
)
+
'
=
'
+
encodeURIComponent
(
data
[
key
]))
}
}
data
=
bodyArray
.
join
(
'
&
'
)
}
}
else
{
headers
[
name
]
=
header
[
name
]
}
}
if
(
!
hasContentType
&&
method
===
'
POST
'
)
{
headers
[
'
Content-Type
'
]
=
'
application/x-www-form-urlencoded; charset=UTF-8
'
}
const
timeout
=
__uniConfig
.
networkTimeout
.
request
if
(
timeout
)
{
abortTimeout
=
setTimeout
(()
=>
{
aborted
=
true
publishStateChange
({
requestTaskId
,
state
:
'
fail
'
,
statusCode
:
0
,
errMsg
:
'
timeout
'
})
},
(
timeout
+
200
))
// TODO +200 发消息到原生层有时间开销,以后考虑由原生层回调超时
}
const
options
=
{
method
,
url
:
url
.
trim
(),
// weex 官方文档有误,headers 类型实际 object,用 string 类型会无响应
headers
,
type
:
responseType
===
'
arraybuffer
'
?
'
base64
'
:
'
text
'
,
// weex 官方文档未说明实际支持 timeout,单位:ms
timeout
:
timeout
||
6
e5
,
// 配置和weex模块内相反
sslVerify
:
!
sslVerify
,
firstIpv4
:
firstIpv4
}
if
(
method
!==
'
GET
'
)
{
options
.
body
=
typeof
data
===
'
string
'
?
data
:
JSON
.
stringify
(
data
)
}
try
{
stream
.
fetch
(
options
,
({
ok
,
status
,
data
,
headers
})
=>
{
if
(
aborted
)
{
return
}
if
(
abortTimeout
)
{
clearTimeout
(
abortTimeout
)
}
const
statusCode
=
status
if
(
statusCode
>
0
)
{
publishStateChange
({
requestTaskId
,
state
:
'
success
'
,
data
:
ok
&&
responseType
===
'
arraybuffer
'
?
base64ToArrayBuffer
(
data
)
:
data
,
statusCode
,
header
:
headers
,
cookies
:
cookiesP
rase
(
headers
)
})
}
else
{
publishStateChange
({
requestTaskId
,
state
:
'
fail
'
,
statusCode
,
errMsg
:
'
abort statusCode:
'
+
statusCode
})
}
})
requestTasks
[
requestTaskId
]
=
{
abort
()
{
aborted
=
true
if
(
abortTimeout
)
{
clearTimeout
(
abortTimeout
)
}
publishStateChange
({
requestTaskId
,
state
:
'
fail
'
,
statusCode
:
0
,
errMsg
:
'
abort
'
})
}
}
}
catch
(
e
)
{
return
{
requestTaskId
,
errMsg
:
'
createRequestTask:fail
'
}
}
return
{
requestTaskId
,
errMsg
:
'
createRequestTask:ok
'
}
}
export
function
createRequestTask
(
args
)
{
return
createRequestTaskById
(
++
requestTaskId
,
args
)
}
export
function
operateRequestTask
({
requestTaskId
,
operationType
}
=
{})
{
const
requestTask
=
requestTasks
[
requestTaskId
]
if
(
requestTask
&&
operationType
===
'
abort
'
)
{
requestTask
.
abort
()
return
{
errMsg
:
'
operateRequestTask:ok
'
}
}
return
{
errMsg
:
'
operateRequestTask:fail
'
}
}
import
{
hasOwn
}
from
'
uni-shared
'
import
{
publish
,
requireNativePlugin
,
base64ToArrayBuffer
}
from
'
../../bridge
'
let
requestTaskId
=
0
const
requestTasks
=
{}
const
publishStateChange
=
res
=>
{
publish
(
'
onRequestTaskStateChange
'
,
res
)
delete
requestTasks
[
requestTaskId
]
}
const
cookiesP
arse
=
header
=>
{
let
cookiesStr
=
header
[
'
Set-Cookie
'
]
||
header
[
'
set-cookie
'
]
let
cookiesArr
=
[]
if
(
!
cookiesStr
)
{
return
[]
}
if
(
cookiesStr
[
0
]
===
'
[
'
&&
cookiesStr
[
cookiesStr
.
length
-
1
]
===
'
]
'
)
{
cookiesStr
=
cookiesStr
.
slice
(
1
,
-
1
)
}
const
handleCookiesArr
=
cookiesStr
.
split
(
'
;
'
)
for
(
let
i
=
0
;
i
<
handleCookiesArr
.
length
;
i
++
)
{
if
(
handleCookiesArr
[
i
].
indexOf
(
'
Expires=
'
)
!==
-
1
||
handleCookiesArr
[
i
].
indexOf
(
'
expires=
'
)
!==
-
1
)
{
cookiesArr
.
push
(
handleCookiesArr
[
i
].
replace
(
'
,
'
,
''
))
}
else
{
cookiesArr
.
push
(
handleCookiesArr
[
i
])
}
}
cookiesArr
=
cookiesArr
.
join
(
'
;
'
).
split
(
'
,
'
)
return
cookiesArr
}
export
function
createRequestTaskById
(
requestTaskId
,
{
url
,
data
,
header
,
method
=
'
GET
'
,
responseType
,
sslVerify
=
true
,
firstIpv4
=
false
}
=
{})
{
const
stream
=
requireNativePlugin
(
'
stream
'
)
const
headers
=
{}
let
abortTimeout
let
aborted
let
hasContentType
=
false
for
(
const
name
in
header
)
{
if
(
!
hasContentType
&&
name
.
toLowerCase
()
===
'
content-type
'
)
{
hasContentType
=
true
headers
[
'
Content-Type
'
]
=
header
[
name
]
// TODO 需要重构
if
(
method
!==
'
GET
'
&&
header
[
name
].
indexOf
(
'
application/x-www-form-urlencoded
'
)
===
0
&&
typeof
data
!==
'
string
'
&&
!
(
data
instanceof
ArrayBuffer
))
{
const
bodyArray
=
[]
for
(
const
key
in
data
)
{
if
(
hasOwn
(
data
,
key
))
{
bodyArray
.
push
(
encodeURIComponent
(
key
)
+
'
=
'
+
encodeURIComponent
(
data
[
key
]))
}
}
data
=
bodyArray
.
join
(
'
&
'
)
}
}
else
{
headers
[
name
]
=
header
[
name
]
}
}
if
(
!
hasContentType
&&
method
===
'
POST
'
)
{
headers
[
'
Content-Type
'
]
=
'
application/x-www-form-urlencoded; charset=UTF-8
'
}
const
timeout
=
__uniConfig
.
networkTimeout
.
request
if
(
timeout
)
{
abortTimeout
=
setTimeout
(()
=>
{
aborted
=
true
publishStateChange
({
requestTaskId
,
state
:
'
fail
'
,
statusCode
:
0
,
errMsg
:
'
timeout
'
})
},
(
timeout
+
200
))
// TODO +200 发消息到原生层有时间开销,以后考虑由原生层回调超时
}
const
options
=
{
method
,
url
:
url
.
trim
(),
// weex 官方文档有误,headers 类型实际 object,用 string 类型会无响应
headers
,
type
:
responseType
===
'
arraybuffer
'
?
'
base64
'
:
'
text
'
,
// weex 官方文档未说明实际支持 timeout,单位:ms
timeout
:
timeout
||
6
e5
,
// 配置和weex模块内相反
sslVerify
:
!
sslVerify
,
firstIpv4
:
firstIpv4
}
if
(
method
!==
'
GET
'
)
{
options
.
body
=
typeof
data
===
'
string
'
?
data
:
JSON
.
stringify
(
data
)
}
try
{
stream
.
fetch
(
options
,
({
ok
,
status
,
data
,
headers
})
=>
{
if
(
aborted
)
{
return
}
if
(
abortTimeout
)
{
clearTimeout
(
abortTimeout
)
}
const
statusCode
=
status
if
(
statusCode
>
0
)
{
publishStateChange
({
requestTaskId
,
state
:
'
success
'
,
data
:
ok
&&
responseType
===
'
arraybuffer
'
?
base64ToArrayBuffer
(
data
)
:
data
,
statusCode
,
header
:
headers
,
cookies
:
cookiesP
arse
(
headers
)
})
}
else
{
publishStateChange
({
requestTaskId
,
state
:
'
fail
'
,
statusCode
,
errMsg
:
'
abort statusCode:
'
+
statusCode
})
}
})
requestTasks
[
requestTaskId
]
=
{
abort
()
{
aborted
=
true
if
(
abortTimeout
)
{
clearTimeout
(
abortTimeout
)
}
publishStateChange
({
requestTaskId
,
state
:
'
fail
'
,
statusCode
:
0
,
errMsg
:
'
abort
'
})
}
}
}
catch
(
e
)
{
return
{
requestTaskId
,
errMsg
:
'
createRequestTask:fail
'
}
}
return
{
requestTaskId
,
errMsg
:
'
createRequestTask:ok
'
}
}
export
function
createRequestTask
(
args
)
{
return
createRequestTaskById
(
++
requestTaskId
,
args
)
}
export
function
operateRequestTask
({
requestTaskId
,
operationType
}
=
{})
{
const
requestTask
=
requestTasks
[
requestTaskId
]
if
(
requestTask
&&
operationType
===
'
abort
'
)
{
requestTask
.
abort
()
return
{
errMsg
:
'
operateRequestTask:ok
'
}
}
return
{
errMsg
:
'
operateRequestTask:fail
'
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录