SAP UI5 应用的 OData 元数据请求的发送原理分析

举报
汪子熙 发表于 2022/10/03 10:24:14 2022/10/03
1.1k+ 0 0
【摘要】 当我们的 SAP UI5 应用里使用了 OData 模型从远端服务器读取数据,具体实现细节可以参考我这篇文章:SAP UI5 初学者教程之二十四 - 如何使用 OData 数据模型,可以在 Chrome 开发者工具里,观察到一个由 SAP UI5 框架自动发出的元数据请求。请求的 url :https://services.odata.org/V2/Northwind/Northwind.s...

当我们的 SAP UI5 应用里使用了 OData 模型从远端服务器读取数据,具体实现细节可以参考我这篇文章:SAP UI5 初学者教程之二十四 - 如何使用 OData 数据模型,可以在 Chrome 开发者工具里,观察到一个由 SAP UI5 框架自动发出的元数据请求。

请求的 url :

https://services.odata.org/V2/Northwind/Northwind.svc/$metadata?sap-language=EN

该请求没有 content-type 字段,只有一个 accept 字段,值为:application/xml

还有一个 MaxDataServiceVersion,值为 3.0

响应的头部字段里,没有 Accept 字段,只有 Content-Type 字段,注意大小写:

具体发起该 HTTP 请求的代码位置:ODataMetadata 的 _loadMetadata 方法:

在构造函数里触发 _loadMetadata:

基于 url 创建 request 对象:

根据如下的 API 获得 HTTP 请求支持的语言:Accept-Language

sap.ui.getCore().getConfiguration().getLanguageTag()

计算出来是:en-US

bAsync 标志位为 true,代表这是个异步请求:

withCredentials 标志位为 false:

然后使用传统的 promise API 发起请求:

如果 metadata 加载成功,就在其回调里执行初始化逻辑:

if (!this.oMetadata.isLoaded()) {
				this.oMetadata.attachFailed(this.onMetadataFailed);
			}

下面调用 OData API,传入刚才构造好的请求对象,进行请求发送:

进入 datajs.js, 首先 prepareRequest:

normalizeHeaders:对头部字段进行规范化处理,其实就是将头部字段转换成小写:

然后调用 invokeRequest 进行发送:

移交给 httpClient:

datajs.js 的底层还是基于 XHR 即 XmlHttpRequest:

直接使用浏览器原生的 XMLHttpRequest:

这里的 fallback 机制用的是已经很古老的 ActiveXObject 了,现代浏览器都不会执行到:

var createXmlHttpRequest = function () {
        /// <summary>Creates a XmlHttpRequest object.</summary>
        /// <returns type="XmlHttpRequest">XmlHttpRequest object.</returns>
        if (window.XMLHttpRequest) {
            return new window.XMLHttpRequest();
        }
        var exception;
        if (window.ActiveXObject) {
            try {
                return new window.ActiveXObject("Msxml2.XMLHTTP.6.0");
            } catch (_) {
                try {
                    return new window.ActiveXObject("Msxml2.XMLHTTP.3.0");
                } catch (e) {
                    exception = e;
                }
            }
        } else {
            exception = { message: "XMLHttpRequest not supported" };
        }
        throw exception;
    };

最后调用 xhr.open:

使用 send api 进行请求发送。

【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

作者其他文章

评论(0

抱歉,系统识别当前为高风险访问,暂不支持该操作

    全部回复

    上滑加载中

    设置昵称

    在此一键设置昵称,即可参与社区互动!

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。