import { Component, OnInit } from '@angular/core'; import { HttpClient } from '@angular/common/http' import { Router } from '@angular/router' import { FormBuilder, FormGroup, Validators } from '@angular/forms'; import { NzMessageService } from 'ng-zorro-antd/message'; import { Base64 } from 'js-base64'; @Component({ selector: 'app-login', templateUrl: './login.component.html', styleUrls: ['./login.component.scss'], }) export class LoginComponent implements OnInit { validateForm!: FormGroup; constructor(private http: HttpClient, private router: Router, private fb: FormBuilder, private message: NzMessageService) { } ngOnInit() { this.validateForm = this.fb.group({ userName: [null, [Validators.required]], password: [null, [Validators.required]], remember: [null], autologin: [null], }); //如果本地储存了账号密码信息,那就回显在输入框 let account = localStorage.getItem('account') let password = localStorage.getItem('password') if (account && password) { this.validateForm.patchValue({ userName: Base64.decode(localStorage.getItem('account')), password: Base64.decode(localStorage.getItem('password')) }); this.remember = true //这一步是回显后让勾选框为选中状态 } //自动登录 if (localStorage.getItem('isautologin') == 'true') { this.submitForm() this.autologin = true //这一步是回显后让勾选框为选中状态 } } errmsg: string = ''; //错误信息 // //跳转注册页面 // toRegister() { // this.router.navigate(['/register']) // } //记住密码 rememberInfo() { // 判断用户是否勾选记住密码,如果勾选,在本地储存中储存登录信息 if (this.remember) { localStorage.setItem("account", Base64.encode(this.validateForm.value.userName)) localStorage.setItem("password", Base64.encode(this.validateForm.value.password)) } } //自动登录 autoLogin() { if (this.autologin) { localStorage.setItem("isautologin", 'true') } } remember: any//记住密码 autologin: any//自动登录 isLoading = false; messages: any encryptedAccessToken: any submitForm(): void { if (!this.remember) { localStorage.removeItem("account") localStorage.removeItem("password") } if (!this.autologin) { localStorage.removeItem("isautologin") } for (const i in this.validateForm.controls) { this.validateForm.controls[i].markAsDirty(); this.validateForm.controls[i].updateValueAndValidity(); } if (!this.validateForm.valid) { this.message.create('error', `请输入账号密码`); return } this.isLoading = true; this.http.post('/api/Accounts/SignIn', { username: this.validateForm.value.userName, password: this.validateForm.value.password }).subscribe({ next: (data: any) => { sessionStorage.setItem("token", data.token); sessionStorage.setItem("refreshToken", data.refreshToken); this.http.get('/api/Accounts/Profile').subscribe({ next: (data: any) => { console.log('登录用户信息', data) this.isLoading = false; this.rememberInfo() this.autoLogin() this.router.navigate(['/system']) this.message.create('success', `登录成功`); sessionStorage.setItem("userData", JSON.stringify(data)); }, error: (err) => { this.isLoading = false; } }) }, error: (err) => { this.isLoading = false; } }) } forget() { this.message.create('warning', `请联系管理员`); } }