我尝试用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}
答案 0 :(得分:-1)
从ios项目中删除webkit
插件,它将开始工作。