在tns buid android --release应用程序未进行REST调用之后

时间:2019-12-10 09:27:56

标签: android angular nativescript nativescript-angular

替换为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

1 个答案:

答案 0 :(得分:0)

我解决了将http客户端从Http的{​​{1}}(不推荐使用)更改为@angular/core的{​​{1}}的问题。