是否可以使用Cookie登录B1 ServiceLayer

2020-09-14 18:47发布

点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)大家好, 我正在尝试创...

         点击此处--->   EasySAP.com群内免费提供SAP练习系统(在群公告中)

加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)


大家好,

我正在尝试创建一个HTML5应用程序,该应用程序在重新加载页面后将保持登录到ServiceLayer会话中。

如果我使用邮递员登录服务层,则会得到以下标题详细信息:

连接→保持活动
 内容编码→gzip
 内容长度→174
 内容类型→application/json; odata =最小元数据; charset = utf-8
 DataServiceVersion→3.0
 日期→2018年8月16日,星期四06:10:06 GMT
 保持活动→超时= 15,最大= 100
 服务器→Apache
 Set-Cookie→B1SESSION = 0669e842-a11b-11e8-8000-000c29594cad; HttpOnly;
 Set-Cookie→HASH_B1SESSION = 4548D83BAFE012C7E2BA5E30A504D30B19CEC467;  HttpOnly
 变化→接受编码
 

我尝试访问JS应用程序内部的Set-Cookie无济于事。

我在JS应用程序中的登录如下:

 $ .ajax({
 网址:serviceLayerLoginURL,
 xhrFields:{
 withCredentials:正确
 },
 数据:jData = JSON.stringify({
 用户名:用户,
 密码:pass,
 CompanyDB:comp
 }),
 输入:" POST",
 dataType:" json",
 成功:功能(r,状态,xhr){
 app.SessionId = r.SessionId;
 app.to(" tilesPage");
 sap.ui.core.BusyIndi​​cator.hide();
 },
 错误:this.onErrorCall
 });
 

现在我的问题是:如何访问正确的信息,以及如何使用它们在没有用户名,密码和可选的CompanyDB的情况下登录?

4条回答
spaceman01
2020-09-14 18:57

嗨,曼努埃尔,

仅在发布到"登录"资源时需要传递CompanyDB,用户名和密码。 没有凭据就无法登录。

当您致电Login时,将从服务器中返回cookie(B1SESSION和ROUTEID),并且您必须将它们用于任何其他请求(包括Logout)。

逻辑如下:

  1. 使用您的正文请求中的凭据发布到/登录
  2. 服务器返回cookie
  3. 您仅请求使用此cookie的另一个资源(浏览器将自动添加此cookie)
  4. ...
  5. 发布到/登出一个空的正文和您的cookie以关闭会话

以下是ServiceLayer文档中的信息:

登录

使用指定的凭据登录服务层。 通常,这是使用服务层API的第一步。 在没有登录的情况下调用服务层API将导致失败。 成功登录后,HTTP响应正文中将返回一个会话ID。 同时,将设置两个名为" B1SESSION"和" ROUTEID"的HTTP cookie项目。 如果在浏览器中调用服务层API,则无需与它们相关联,因为浏览器将在后续的HTTP请求中将它们自动发送到服务层。 您确实需要在随后的服务层API调用中将它们添加到HTTP标头中。 否则,服务层会将其视为没有登录的错误请求。

一周热门 更多>