Как подтвердить электронную почту, используя Angular и ASP. NET Core 3.1 - PullRequest
1 голос
/ 08 апреля 2020

Я использую Angular 9 (localhost: 4200) и WebAPI с do tnet Core 3.1 (localhost: 5000). Во время регистрации пользователя я передаю данные пользователя с Клиента на Сервер, а затем в методе «Регистрация» отправляю ему электронное письмо для проверки. После того, как пользователь щелкает ссылку, он перенаправляет его на метод localhost: 5000 для VerifyEmail.

Как создать ссылку в функции регистрации, чтобы код мог сначала выполнить функцию клиента, а затем подтвердить проверку на сервере? Или есть лучший способ подтверждения электронной почты с помощью Angular / do tnet core WebApi?

Клиентская сторона:

import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { User } from '../_models/user';
import { environment } from '../../environments/environment';

@Injectable({
  providedIn: 'root'
})
export class AuthService {
baseUrl = environment.apiUrl + 'auth/';

constructor(private http: HttpClient) {}

register(user: User) {
    return this.http.post(this.baseUrl + 'register', user);
  }
}

verifyEmail(data: any) {     // not used 
    return this.http.post(this.baseUrl + 'VerifyEmail', data);
  }

Серверная сторона:

[HttpPost("register")]
        public async Task<IActionResult> Register(UserForRegisterDto userForRegisterDto)
        {
            var code = string.Empty;
            var userToCreate = _mapper.Map<User>(userForRegisterDto);
            try
            {
                var userExists = await _userManager.FindByNameAsync(userToCreate.UserName);
                if (userExists == null)
                {
                    var result = await _userManager.CreateAsync(userToCreate, userForRegisterDto.Password);
                    code = await _userManager.GenerateEmailConfirmationTokenAsync(userToCreate);
                    if (result.Succeeded)
                    {
                        //some code
                    }
                }
                else
                {
                    var emailConfirmed = await _userManager.IsEmailConfirmedAsync(userExists);
                    code = await _userManager.GenerateEmailConfirmationTokenAsync(userExists);
                    if (emailConfirmed)
                    {
                        return Ok();
                    }
                }

                var link = Url.Action(nameof(VerifyEmail), "Auth", new { userId = userToCreate.Id, code }, Request.Scheme, Request.Host.ToString());

                await _emailService.SendAsync("test@test.com", "email verify", $"<a href=\"{link}\">Verify Email</a>", true);
            }
            catch (Exception ex)
            {
                throw;
            }
            return Ok();
        }

public async Task<IActionResult> VerifyEmail(string userId, string code)
        {
            if (string.IsNullOrEmpty(userId) || string.IsNullOrEmpty(code))
            {
                return BadRequest();
            }

            var user = await _userManager.FindByIdAsync(userId);

            if (user == null)
            {
                return BadRequest();
            }

            if (user.EmailConfirmed)
            {
                //return Ok();
            }

            var result = await _userManager.ConfirmEmailAsync(user, code);
            if (result.Succeeded)
            {
                return Ok();
            }

            return BadRequest();
        }

Заранее спасибо за любую помощь и ваше время!

1 Ответ

0 голосов
/ 09 апреля 2020

Я бы создал новый angular компонент, который разрешает / проверяет маршрут электронной почты и оттуда называется AuthService

import { Component, OnInit } from '@angular/core';

@Component({
  selector: 'email-verification',
  template: '<h1>{{status}}</h1>',
  styleUrls: [ './email-verification.component.css' ]
})
export class EmailVerificationComponent implements OnInit  {
  status: string = "Verifying...";
  constructor(private authService: AuthService){}

  ngOnInit() {
    this.authService.verifyEmail().subscribe(_ => this.status = "Email verified!");
    //redirect to another component
  }
}
...