SAP UI5 框架是如何执行 batch 请求的单步调试

简介: SAP UI5 框架是如何执行 batch 请求的单步调试

req.get(‘content-type’)

正常的 batch 操作,response 的 content-type 不应该返回 html 类型:

正确的 batch response,Content-Type 值应该是 multipart/mixed; boundary=batchresponse_后面跟一个 guid


success handler 即下图的 fnSuccess, 被包裹在 wraHandler 里。

content-type 不同的 response,对应有不同的 handler 来处理。


httpClient.request 如果执行出错,会进入到 catch 分支,错误消息:

invalid MIME part type


使用分号将 multipart/mixedboundary 的具体值分隔开。

每种类型都有对应的 handler,由对应的 handler 调用 read 方法执行 response 的解析操作。


解析 batch 操作的响应:

在出错情况下,从 Chrome 开发者工具 network 标签页里下载 batch 响应到本地,和不出错的场景比较,格式上没有任何差异:


问题出在 batch response 的 header 里的 Content-Type 字段。

chrome 里看到的 content-type 不是这个啊:


body 是 null,所以进不去 7884 行的 dispatchHandler 函数:


multipart/mixed MIME 消息由不同数据类型的混合组成。 每个 body part 都由一个 boundary 划定。 boundary 参数是一个文本字符串,用于将消息正文的一部分与另一部分区分开来。 所有边界都以两个连字符 hyphens (–) 开头。 最后的边界也以两个连字符 (–) 结束。 边界可以由除空格、控制字符或特殊字符之外的任何 ASCII 字符组成。


如果我们通过 batch 请求向服务器发送一个 word 文档,则 HTTP body payload 的例子如下:


Content-type: multipart/mixed;

boundary="Boundary_any ascii character except some of the following special characters:



( )< > @ , ; : \ / [ ] ? = "

"

–Boundary_any ASCII character, except some special characters below:

content-Type: text/plain;----

charset=iso-8859-1

Content-transfer-encoding: 7BIT

–Boundary_ASCII characters

Content-type: application/msword;

name=“message.doc”

Content-Transfer-Encoding: base64


在 multipart 消息正文的情况下,一个或多个不同的数据集组合在一个正文中,值为 multipart 的 Content-Type 字段必须出现在 HTTP request entity 的头部字段中。正文部分在语法上类似于 RFC 822 消息,只是含义不同。

相关文章
|
26天前
|
小程序 JavaScript 前端开发
小程序常见的UI框架
小程序常见的UI框架
|
8天前
|
JavaScript
Ant Design Vue UI框架的基础使用,及通用后台管理模板的小demo【简单】
这篇文章介绍了如何使用Ant Design Vue UI框架创建一个简单的后台管理模板,包括创建Vue项目、安装和使用ant-design-vue、以及编写后台管理通用页面的代码和样式。
Ant Design Vue UI框架的基础使用,及通用后台管理模板的小demo【简单】
|
17天前
|
JavaScript
从零开始写一套广告组件【一】搭建基础框架并配置UI组件库
其实这个从零有点歧义,因为本质上是要基于`tdesign-vue-next`来进行二次封装为一套广告UI组件库,现在让我们在一起快乐的搭建自己的广告UI库之前,先对以下内容做出共识:
33 0
从零开始写一套广告组件【一】搭建基础框架并配置UI组件库
|
29天前
|
Linux C# Android开发
一个开源、跨平台的.NET UI框架 - Avalonia UI
一个开源、跨平台的.NET UI框架 - Avalonia UI
|
2月前
|
前端开发 关系型数据库 MySQL
Python基于Django框架图书管理系统,Bootstrap框架UI,后台EasyUI框架UI,有登录,实现增删改查的富文本效果
本文介绍了一个使用Python Django框架开发的图书管理系统,该系统采用Bootstrap框架进行前端UI设计,EasyUI框架用于后台UI界面,集成了富文本编辑器,并实现了登录及增删改查功能。
|
2月前
|
JavaScript 前端开发
Vue实现Element UI框架的自定义输入框或下拉框在输入时对列表选项进行过滤,以及右键列表选项弹出菜单进行删除
本文介绍了如何在Vue框架结合Element UI库实现自定义输入框或下拉框,在输入时对列表选项进行过滤,并支持右键点击列表选项弹出菜单进行删除的功能。
38 0
|
2月前
|
前端开发 Linux API
Avalonia:一个.NET跨平台UI框架
Avalonia:一个.NET跨平台UI框架
76 0
|
4月前
|
小程序 开发者 Windows
轻量、可靠的小程序 UI 框架 -- Vant Weapp的安装和使用
轻量、可靠的小程序 UI 框架 -- Vant Weapp的安装和使用
101 1
|
3月前
|
前端开发 API
前端框架与库 - Material-UI组件库
【7月更文挑战第20天】Material-UI 是一个基于 React 的 UI 组件库,它遵循 Google 的 Material Design 设计规范,提供了丰富的预构建组件,极大地简化了前端开发过程。本文将深入浅出地介绍 Material-UI 的常见问题、易错点及如何避免这些问题,并附带代码示例,帮助你更好地掌握 Material-UI 的使用技巧。
93 0
|
3月前
uniapp 安装插件 uView (多平台快速开发的UI框架)
uniapp 安装插件 uView (多平台快速开发的UI框架)
115 0
下一篇
无影云桌面