Il nuovo framework ASP.NET Identity contiene già tutta una serie di primitive per la gestione delle problematiche più comuni relative all'autenticazione degli utenti.
Il reset password, per esempio, unitamente alla generazione del token da inviare in email all'utente, è una di queste, ed è facilmente abilitabile dal template di progetto di default in Visual Studio 2013. I passaggi sono molto semplici e, una volta compresa la logica, possiamo facilmente integrare la funzionalità in una nostra applicazione esistente.
Il primo passo è quello di includere un link, per default commentato, su Login.cshtml, che rimandi alla pagina di reset della password:
<p> @Html.ActionLink("Forgot your password?", "ForgotPassword")</p>
La action di GET di ForgotPassword di AccountController è semplicemente una form che chiede l'indirizzo email dell'utente e posta sul medesimo URL. La action di POST, poi, si occupa di inviare la mail di reset all'utente:
[HttpPost] [AllowAnonymous] [ValidateAntiForgeryToken] public async Task<ActionResult> ForgotPassword(ForgotPasswordViewModel model) { if (ModelState.IsValid) { var user = await UserManager.FindByNameAsync(model.Email); if (user == null || !(await UserManager.IsEmailConfirmedAsync(user.Id))) { // Don't reveal that the user does not exist or is not confirmed return View("ForgotPasswordConfirmation"); } string code = await UserManager.GeneratePasswordResetTokenAsync(user.Id); var callbackUrl = Url.Action("ResetPassword", "Account", new { userId = user.Id, code = code }, protocol: Request.Url.Scheme); await UserManager.SendEmailAsync(user.Id, "Reset Password", "Please reset your password by clicking <a href=\"" + callbackUrl + "\">here</a>"); return RedirectToAction("ForgotPasswordConfirmation"); } return View(model); }
La logica è molto semplice: innanzi tutto il metodo esegue una verifica sulla correttezza della mail inserita. Come possiamo notare, se questa fallisce, è buona norma dare comunque conferma all'utente del corretto invio della mail, per non fornire informazioni sensibili a un potenziale utente malevolo.
In caso contrario, invochiamo il metodo GeneratePasswordResetTokenAsync di UserManager per generare un nuovo token di reset, che possiamo a questo punto inviare all'utente tramite mail, sotto forma di link alla action ResetPassword. Come possiamo notare, il token appare nella variabile di querystring code.
ResetPassword, nella sua versione in GET, si limita a visualizzare una view di inserimento della nuova password:
[AllowAnonymous] public ActionResult ResetPassword(string code) { return code == null ? View("Error") : View(); }
Ben più interessante è la versione che risponde ai POST, dove abbiamo implementato la logica di reset:
[HttpPost] [AllowAnonymous] [ValidateAntiForgeryToken] public async Task<ActionResult> ResetPassword(ResetPasswordViewModel model) { if (!ModelState.IsValid) { return View(model); } var user = await UserManager.FindByNameAsync(model.Email); if (user == null) { // Don't reveal that the user does not exist return RedirectToAction("ResetPasswordConfirmation", "Account"); } var result = await UserManager.ResetPasswordAsync(user.Id, model.Code, model.Password); if (result.Succeeded) { return RedirectToAction("ResetPasswordConfirmation", "Account"); } AddErrors(result); return View(); }
In particolare, dopo i controlli di validità dell'input, il metodo invoca ResetPasswordAsync che si occupa automaticamente di validare il token, ancora presente in querystring, e di modificare la password dell'utente.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Escludere alcuni file da GitHub Secret Scanning
Disabilitare automaticamente un workflow di GitHub
Come EF 8 ha ottimizzato le query che usano il metodo Contains
Configurare lo startup di applicazioni server e client con .NET Aspire
Creare una libreria CSS universale: Clip-path
Disabilitare automaticamente un workflow di GitHub (parte 2)
Miglioramenti nelle performance di Angular 16
Sfruttare GPT-4o realtime su Azure Open AI per conversazioni vocali
Ottenere un token di accesso per una GitHub App
Generare una User Delegation SAS in .NET per Azure Blob Storage
Modificare i metadati nell'head dell'HTML di una Blazor Web App
Eseguire un metodo asincrono dopo il set di una proprietà in Blazor 8
I più letti di oggi
- Community Night@Basta!Italia on tour 2009 - Milano
- Real Code Day - Firenze
- Real Code Conference 4.0 - Firenze
- Windows Phone r8me - Roma
- Visual Studio 2008 Team Suite in RTM su MSDN Download
- Rilasciata la prima CTP del .NET Parallel Framework
- Annunciata la modalità di uscita di ADO.NET Entity Framework e dei Data Services