0

我正在开发新的 Platform MFP8,我想在混合应用程序中实现 LTPA 身份验证。在网上搜索,我发现了 LTPA ChallengeHandler 的 Swift 实现(https://github.com/mfpdev/ldap-and-ltpa-sample/tree/master/LTPABasedSample)。但是,如果我尝试在 JS challengeHandler 中复制相同的行为,它就不起作用。在我的 challengeHandler 实现下面:

var UserLoginChallengeHandler = function() {
    var isChallenged = false;
    var securityCheckName = 'LTPA';
    var URL;
    var userLoginChallengeHandler = WL.Client.createSecurityCheckChallengeHandler(securityCheckName);

    document.getElementById("login").addEventListener("click", login);

    userLoginChallengeHandler.securityCheckName = securityCheckName;

    userLoginChallengeHandler.handleChallenge = function(challenge) {
        WL.Logger.debug("handleChallenge");
        showLoginDiv();
        isChallenged = true;
        URL = challenge.loginURL;
    };

    userLoginChallengeHandler.handleSuccess = function(data) {
        WL.Logger.debug("handleSuccess");
        isChallenged = false;
        showProtectedDiv();
    };

    userLoginChallengeHandler.handleFailure = function(error) {
        WL.Logger.debug("handleFailure: " + error.failure);
        isChallenged = false;
        if (error.failure !== null){
            alert(error.failure);
        } else {
            alert("Failed to login.");
        }
    };

    function login() {

        var basic = "Basic YWRtaW46YWRtaW4="; //base64 of admin:admin 
        $.ajax({
          type: "POST",
          url: URL,
          headers: {
            "Authorization": basic
          },
          success: function(data, status, xhr){
            console.log(data);
            userLoginChallengeHandler.submitChallengeAnswer({});
          },
          error: function(jqXhr, status, error){
            console.log(error);
          }
        });
    }

    return userLoginChallengeHandler;

};

当我提交对plain-war 应用程序的请求时,LTPASecurityCheck 的授权方法中的主体结果为空。相反,如果我执行 iOS 示例应用程序,则会对主体进行评估并进行身份验证。

你有什么想法来解决这种奇怪的行为吗?

非常感谢,斯特凡诺

4

1 回答 1

1

我认为 Swift 示例不是发送 POST 请求而是发送 GET。您是否尝试将其作为 GET 发送?

于 2017-01-17T15:17:31.257 回答