我创建了 login-service
,其中包含使用google,facebook或twitter登录的选项,并且运行良好 .
我正在尝试创建使用电子邮件和密码登录的选项(该选项在firebase控制台中启用),我无法使其正常工作 .
我的登录服务代码如下:
import {Injectable, OnInit} from '@angular/core';
import {AngularFire, AuthProviders, AuthMethods} from "angularfire2/angularfire2";
@Injectable()
export class LoginService implements OnInit {
public isLoged: boolean;
ngOnInit() {
}
constructor(private af: AngularFire) {
this.af.auth.subscribe(user => {
if (user) {
this.isLoged = true;
console.info("Se ha logueado correctamente")
} else {
this.isLoged = false;
console.info("Se ha deslogueado correctamente");
}
});
}
login() {
this.af.auth.login();
}
loginGoogle() {
//this is the default login , that it's setup in the main.js
this.login();
}
loginFacebook() {
this.af.auth.login({
provider: AuthProviders.Facebook,
method: AuthMethods.Redirect
});
}
loginTwitter() {
this.af.auth.login({
provider: AuthProviders.Twitter,
method: AuthMethods.Redirect
});
}
createUser(email: string, password: string) {
this.af.auth.createUser({ email: email, password: password });
}
loginWithPassword() {
this.af.auth.login({
provider: AuthProviders.Password,
method: AuthMethods.Password
})
}
logOut() {
this.af.auth.logout();
}
}
主要是:
import { APP_BASE_HREF } from '@angular/common';
import { disableDeprecatedForms, provideForms } from '@angular/forms';
import { enableProdMode } from '@angular/core';
import { bootstrap } from '@angular/platform-browser-dynamic';
import { APP_ROUTER_PROVIDERS } from './app.routes';
import { AppComponent } from './app.component';
import {
FIREBASE_PROVIDERS, defaultFirebase, firebaseAuthConfig, AuthProviders,
AuthMethods
} from "angularfire2/angularfire2";
if ('<%= ENV %>' === 'prod') { enableProdMode(); }
/**
* Bootstraps the application and makes the ROUTER_PROVIDERS and the APP_BASE_HREF available to it.
* @see https://angular.io/docs/ts/latest/api/platform-browser-dynamic/index/bootstrap-function.html
*/
bootstrap(AppComponent, [
disableDeprecatedForms(),
provideForms(),
APP_ROUTER_PROVIDERS,
{
provide: APP_BASE_HREF,
useValue: '<%= APP_BASE %>'
},
FIREBASE_PROVIDERS,
defaultFirebase({ //this data is replaced
apiKey: 'apiKey',
authDomain: 'authDomain',
databaseURL: 'databaseURL',
storageBucket: 'storageBucket',
}),
firebaseAuthConfig({
provider: AuthProviders.Google,
method: AuthMethods.Popup,
})
]);
Update :
正如@JS_astronauts所说,问题与数据如何传递给登录服务有关,现在我发现从调用loginService没有得到params权限,我正在使用这样的FormBuilder:
login.component.ts
import { Component, OnInit } from '@angular/core';
import {FormBuilder, Validators, ControlGroup ,NgFormModel} from '@angular/common'
import {AngularFire, AuthProviders, AuthMethods} from 'angularfire2';
import {LoginService} from '../shared/login-service/login.service'
import {Router} from "@angular/router";
@Component({
moduleId: module.id,
selector: 'login',
templateUrl: 'login.component.html',
styleUrls : ['login.component.css'],
directives : [NgFormModel]
})
export class LoginComponent implements OnInit {
loginForm : ControlGroup;
constructor(private router: Router,
private fb : FormBuilder,
private loginService : LoginService) {
this.loginForm = fb.group({
name : ["" , Validators.required],
correo : ["" , Validators.required],
contrasena :["",Validators.required]
})
}
ngOnInit() {
}
loginWithPassword(){
this.loginService.createUser(
this.loginForm.controls['correo'].value.toString() ,
this.loginForm.controls['contrasena'].value.toString()
);
if(this.loginService.isLoged ){
this.router.navigate(['./ejemplo']);
}
}
}
在我的HTML中:
<form [ngFormModel]="loginForm" (submit)="loginWithPassword()">
<div id="DIV_13">
<div id="DIV_14">
<span id="SPAN_15"> <i id="I_16">face</i></span>
<div id="DIV_17">
<input ngControl="name" type="text" placeholder="First Name..." id="INPUT_18" /><span id="SPAN_19"></span>
</div>
</div>
<div id="DIV_20">
<span id="SPAN_21"> <i id="I_22">email</i></span>
<div id="DIV_23">
<input ngControl="correo" type="text" placeholder="Email..." id="INPUT_24" /><span id="SPAN_25"></span>
</div>
</div>
<div id="DIV_26">
<span id="SPAN_27"> <i id="I_28">lock_outline</i></span>
<div id="DIV_29">
<input ngControl="contrasena" type="password" placeholder="Password..." id="INPUT_30" /><span id="SPAN_31"></span>
</div>
</div>
</div>
<div id="DIV_32">
<button type="submit" id="A_33">Get Started</button>
</div>
</form>
但是我用this.loginForm.controls ['correo'] . value.toString()获得的值等于null,那么我如何获得该值?
知道问题出在哪里?关心罗伯托 .
2 回答
如果您无法使用用户数据登录,则数据如何传递到登录服务存在问题 .
Plunker
这是一个例子 with User servic e:
登录组件:
Simple user login:
angularfire2 :plunker
登录组件类:
服务:
引导:
我发现了问题,问题是我需要在html中输入“[]”ngFormModel的指令,并将指令“FORM_DIRECTIVES”添加到logig.component.ts上的组件中 .
PS:使用ngFormModel我在控制台中收到一条信息消息,警告我该指令将在下一个RC中选择加入,并最终将被删除以支持新的表单模块,因此这个实现将不起作用未来