Ionic2:Http发送{“isTrusted”:true} - 与其他可观察者冲突?

时间:2016-03-08 12:24:57

标签: android http angular ionic2

我尝试用Ionic2开发我的新应用程序。在此上下文中,应该使用预共享令牌对用户进行身份验证,该令牌将被发送到api(http请求)。作为响应,他获得了一个访问令牌,他可以使用它进一步使用api函数。

问题是,当我发送HTTP请求时,我得到一个错误: { “_body”:{ “isTrusted”:真}, “状态”:200, “状态文本”: “OK”, “标题”:{}, “类型”:3, “URL”:空}

在我的桌面版中一切正常,但在Android上我收到此错误。我仍然用Google搜索这个错误,我猜这个http请求与其他observable(Form observable)冲突。

如果有人可以帮助我避免这种“错误”,我会很高兴。 作为一个小提示:{“isTrusted”:true}是方法handleSubmit的事件值的值。谢谢: - )

解决方案: 抛出此错误是因为无法访问api(在我的情况下由于证书错误)。如果您有相同的错误: 检查type =“3”,那么您的http目标可能也无法访问。

我的模板:

<ion-content padding class="token-auth">
  <form [ngFormModel]="authForm" (submit)="handleSubmit($event)">
    <ion-item>
      <ion-label floating>Device-ID</ion-label>
      <ion-input (keyup)="onKeyUp($event)" [ngFormControl]="token" type="text"></ion-input>
    </ion-item>

    <div *ngIf="error !== null"
         class="error-box">
      {{error.message}}
    </div>

    <button block type="submit" [disabled]="!authForm.valid">
      Register device
    </button>

  </form>
</ion-content>

页面来源:

handleSubmit(event) : void {          
  this.tokenService.sendAccessTokenRequest(this.authForm.value.token, (err, code) => {
        this.error = {
            code : code,
            message : err
        };
    }, (accessToken, refreshToken, validTill) => {
        this.error = null;
    });
}

TokenService:

/**
 *
 * @param token
 * @param errCallback : (message : string, code : number) => any
 * @param callback : (accessToken : string, refreshToken : string, validTill : string) => any
 */
public sendAccessTokenRequest(token : string, errCallback, callback) {
    if (typeof token === 'undefined') {
        throw 'Token value must be set. ';
    }
    if (typeof errCallback === 'undefined') {
        errCallback = (code, message) => null;
    }
    if (typeof callback === 'undefined') {
        callback = (accessToken, refreshToken, validTill) => null;
    }

    console.log(`Should send token: ${token}`);

    this.sendPost(`/auth/login`, `application=XXX&device_token=${token}`)
        .subscribe(res => {
            console.log("Device verified: "+JSON.stringify(res));
            let {
                access_token,
                refresh_token,
                valid_till
            } = res.data.token;
            this._saveTokenData(access_token, refresh_token, new Date(valid_till));
            callback(access_token, refresh_token, valid_till);
        },
        err => {
            // error is here!
            if (err && err._body) {
                console.log("ERROR: "+JSON.stringify(err));
                try {
                    let bodyData = JSON.parse(err._body);
                    let responseData = bodyData["data"];
                    let token:MessageResponse = responseData.token;
                    if (token && typeof token.code !== 'undefined' && typeof token.userMessage !== 'undefined') {
                        errCallback(token.userMessage, token.code);
                    } else {
                        errCallback(bodyData);
                    }
                } catch (e) {
                    errCallback(e);
                }
            }
        },
        () => console.log("access token request successful")
    );
}

// just an excerpt from other url
sendPost(link : string, params : string, header : Object = {}) {
    console.log("SEND POST");
    link = this._enforceSlashAtStringStart(link);
    return this.http.post(`${this.base_url}${link}`, params, {
        headers : this._mergeHeader(this.getHeader(), header)
    }).map(res => { console.log("Start mapping! "); return res.json(); });
}

// EDIT: added function _saveTokenData
private _saveTokenData(accessToken : string, refreshToken : string, validTill : Date) {
        if (!accessToken || !refreshToken || !validTill) {
            throw new Error('access token data can not be null or undefined! ');
        }

        console.log("TOKEN SAVED!");

        this._accessToken = accessToken;
        this._refreshToken = refreshToken;
        this._validTill = validTill;

        // this._storage = new Storage(LocalStorage);
        this._storage.set(TOKEN_STORAGE_KEY, JSON.stringify({
            access_token : accessToken,
            refresh_token : refreshToken,
            valid_till : validTill.toString()
        }));
    }

最后但并非最不重要的是日志:

14    256534   log      Should send token: XXXXXXXXXXXXXX
15    256548   log      SEND POST
16    256750   log      ERROR: {"_body":{"isTrusted":true},"status":200,"statusText":"Ok","headers":{},"type":3,"url":null}

1 个答案:

答案 0 :(得分:-1)

从ios项目中删除webkit插件,它将开始工作。