替换为this
我用NativeScript + Angular编写了一个跨平台的应用程序。
我使用以下命令创建.keystore文件(如documentation所示):
keytool -genkey -v -keystore <my-release-key>.keystore -alias <alias_name> -keyalg RSA -keysize 2048 -validity 10000
我使用以下命令构建发行版APK:
tns build android --release --key-store-path "C:\Program Files\Java\jre1.8.0_201\bin\<name>.keystore" --key-store-password <password> --key-store-alias <alias> --key-store-alias-password <alias-password>
然后,我在我的Android设备(Android 9和Android 8)上安装了apk文件,但是当我尝试登录(=>进行REST调用)时,它什么也没做。 没有显示任何内容,没有错误,也没有进行呼叫。
我正在使用Nativescript的6.2.0版本。 将项目迁移到NativeScript 6后,我发现了这个问题。
我在哪里错了?我错过了什么吗?
更新
我用run
而不是build
尝试了第二个命令,但是当我按下登录按钮时,控制台什么都没有显示。
控制台rimain停留在这句话上:
已成功安装在标识符为'xxxxxx'的设备上。
更新
我删除了“挂钩”,“ node_modules”和“平台”文件夹,然后重新构建了应用程序,但未进行任何更改。
更新 这是按钮的代码。
当我按下带有空电子邮件和空密码的按钮时,将发出第一个警报。
当我按下具有所有凭据的按钮时,将发出第二个警报。
即使凭据是正确的,也不会提出第三个。
login.component.ts
public login() {
if(!this.user.email || !this.user.password){
let options = {
title: 'ATTENZIONE!',
message: 'Inserire tutte le credenziali',
okButtonText: 'OK'
};
alert(options); //first
} else {
alert("HELLO WORLD!"); //second
this.userService.login(this.user).subscribe((res) => {
alert(res); //third
localStorage.setItem("authenticated", true);
localStorage.setItem("access_token", "bearer " + res.access_token);
localStorage.setItem("username", this.user.email);
},
(err)=>{
console.log("Something went wrong "+err);
alert("Credenziali errate");
return;
}
);
}
return;
}
user.service.ts
login(user: User) {
let urlSearchParams = new URLSearchParams();
urlSearchParams.append('username', user.email);
urlSearchParams.append('password', user.password);
urlSearchParams.append('grant_type','password');
let body = urlSearchParams.toString();
var url = Config.apiUrl + "/token";
return this.http.post(url, body , { headers : this.getCommonHeaders() })
.map(res => res.json())
.catch( (error: any) => {Observable.throw(error.json().error)} );
}
http
来自@angular/http
答案 0 :(得分:0)
我解决了将http客户端从Http
的{{1}}(不推荐使用)更改为@angular/core
的{{1}}的问题。