关于javascript:SAP-UI5-batch-请求的响应解析流程分析

47次阅读

共计 1115 个字符,预计需要花费 3 分钟才能阅读完成。

batch 申请的回复:

应用适合的 handler 解析:

该 handler accept 字段:multipart/mixed

首先依据响应字段,获取 content-type:

content-type 字段,通过 ; 分隔:

media type:multipart/mixed

返回一个 JSON 对象,蕴含 mediaType 和 boundary 属性:

batch 申请的处理器是 batchParser:

执行下一行 readBatch 办法:

boundary 的一个例子:batchresponse_16aba97e-4311-41a4-8c64-302727d1d02e
readBatch 的具体解决逻辑还是,基于字符串匹配,即应用 indexOf 查找 boundary 字符串:

readline 的实现就是读取单行:

batch 第一个 part 的头部字段被读取了进去:

media type 必须和硬编码的值统一:application/http

batch 蕴含的第一个申请 count 的数据曾经读取胜利了:

曾经读取胜利了,还要 dispatch:

count 的 media-type 是 text/plain:

return false 了,response 的 body 有值,data 为 undefined:

有 4 个可用的 handler:

text/plain 负责读取 response.body.

textParser 的逻辑最简略,间接返回 body 字段给 response.data:

读取第二个 part:

这个 part 的 content-type 为 json,因而应用 json handler:

if (handlerAccepts(handler, cType)) {var readContext = createReadWriteContext(cType, version, context, handler);
            readContext.response = response;
            response.data = parseCallback(handler, body, readContext);
            return response.data !== undefined;
        }

上述代码的语义是,只有当一个 handler 通过了函数 handlerAccepts 的过滤之后,能力调用 parseCallback,将解析的后果,传递给 response.data.

json handler 应用 JSON.parse 原生 API 进行 json 数据的序列化操作。

序列化胜利的 json 数据:

最初返回的 response 是一个数组:

调用最外层的 success handler:

batch 申请的回调函数,在函数 _submitBatchRequest 外部:

更多 Jerry 的原创文章,尽在:” 汪子熙 ”:

正文完
 0