MobileFirst - 呼叫适配器 - ERR_CONNECTION_RESET

时间:2017-04-03 09:28:29

标签: javascript android ibm-mobilefirst worklight-adapters mobilefirst-adapters

我从我的应用程序调用MobileFirst适配器时遇到问题。 如果我使用swagger docs或postman测试适配器方法,它可以工作。 不幸的是,从应用预览中,我收到了消息:

  

http://localhost:6015/mfp/api/adapters/ServiceAdapter/login?params=%5Btest%2C%20test123%5D net :: ERR_CONNECTION_RESET

我不明白为什么从我的应用程序向适配器的请求被转发到端口6015.在测试期间(招摇和邮递员)我使用9080,也许这是问题,但我不知道知道如何将应用目标端口从6015更改为9080。

adapter xml:

<mfp:adapter name="ServiceAdapter"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xmlns:mfp="http://www.ibm.com/mfp/integration"
         xmlns:http="http://www.ibm.com/mfp/integration/http">

<displayName>ServiceAdapter</displayName>
<description>ServiceAdapter</description>
<connectivity>
    <connectionPolicy xsi:type="http:HTTPConnectionPolicyType">
        <protocol>http</protocol>
        <domain>localhost</domain>
        <port>53873</port>
        <connectionTimeoutInMilliseconds>30000</connectionTimeoutInMilliseconds>
        <socketTimeoutInMilliseconds>30000</socketTimeoutInMilliseconds>
        <maxConcurrentConnectionsPerNode>50</maxConcurrentConnectionsPerNode>
    </connectionPolicy>
</connectivity>

<procedure name="login" secured="false" />

实现:

function login(login, pass) {
    path = 'token';
    var input = {
        method : 'post',
        returnedContentType : 'json',
        path : path,
        headers : {
            'Content-Type' : 'application/x-www-form-urlencoded'
        },
        body : {
            contentType : 'application/x-www-form-urlencoded',
            content : 'username=' + login + '&password=' + pass + '&grant_type=password'
        }
    };
    return MFP.Server.invokeHttp(input);
}

和适配器调用:

function Login() {
    var resourceRequest = new WLResourceRequest(
            "/adapters/ServiceAdapter/login",
            WLResourceRequest.GET
    );

    resourceRequest.setQueryParameter("params", "[" + $("#log").val() + ", " + $("#pass").val() + "]");
    resourceRequest.send().then(LoginSuccess, LoginFailure);
}

编辑6.04.2017:
另外,我注意到,在适配器调用的那一刻,我从 previewCordova.js 文件在控制台中收到此错误。它看起来像变量 req.url 未定义:

C:\...\npm\node_modules\mfpdev-cli\node_modules\mdo-app-preview\lib\previewCordova.js:579
    if(!req.url.startsWith('/')) {
                ^
TypeError: undefined is not a function
    at Server.<anonymous> (C:\..\npm\node_modules\mfpdev-cli\node_modules\mdo-app-preview\lib\previewCordova.js:579:17)
    at Server.emit (events.js:110:17)
    at HTTPParser.parserOnIncoming [as onIncoming] (_http_server.js:491:12)
    at HTTPParser.parserOnHeadersComplete (_http_common.js:111:23)
    at Socket.socketOnData (_http_server.js:343:22)
    at Socket.emit (events.js:107:17)
    at readableAddChunk (_stream_readable.js:163:16)
    at Socket.Readable.push (_stream_readable.js:126:10)
    at TCP.onread (net.js:538:20)

2 个答案:

答案 0 :(得分:2)

Mobilefirst App Preview通过在端口6015上运行的代理连接到MFP服务器,您面临的行为是正常的,它与端口无关。

ERR_CONNECTION_RESET错误是由于浏览器&amp;而不是来自Mobilefirst Server。

尝试使用不同的浏览器发出请求,并尝试清除浏览数据/缓存。

答案 1 :(得分:0)

我已经解决了一个问题。我的NodeJS版本不支持javascript String.prototype.startsWith方法。所以我已将此方法添加到previewCordova.js文件:

if (!String.prototype.startsWith) {
  String.prototype.startsWith = function(searchString, position) {
    position = position || 0;
    return this.indexOf(searchString, position) === position;
  };
}

较新版本的NodeJS已实施startsWith方法,因此NodeJS升级也应解决问题。