Condividi tramite


Recupero e modifica delle password (VB)

di Scott Mitchell

Nota

Poiché questo articolo è stato scritto, i provider di appartenenza ASP.NET sono stati sostituiti da ASP.NET Identity. È consigliabile aggiornare le app per usare ASP.NET Identity Platform anziché i provider di appartenenze presenti al momento della scrittura di questo articolo. ASP.NET Identity offre numerosi vantaggi rispetto al sistema di appartenenza ASP.NET, tra cui :

  • Prestazioni migliori
  • Estendibilità e testbilità migliorate
  • Supporto per OAuth, OpenID Connect e autenticazione a due fattori
  • Supporto delle identità basate sulle attestazioni
  • Migliore interoperabilità con ASP.Net Core

ASP.NET include due controlli Web per agevolare il ripristino e la modifica delle password. Il controllo PasswordRecovery consente a un visitatore di recuperare la password persa. Il controllo ChangePassword consente all'utente di aggiornare la password. Analogamente agli altri controlli Web correlati all'accesso illustrati in questa serie di esercitazioni, i controlli PasswordRecovery e ChangePassword funzionano con il framework di appartenenza in background per reimpostare o modificare le password degli utenti.

Introduzione

Tra i siti Web per la mia banca, società di utilità, società telefonica, account di posta elettronica e portali Web personalizzati, mi piace la maggior parte delle persone, hanno decine di password diverse da ricordare. Con così tante credenziali da memorizzare in questi giorni, non è insolito per le persone dimenticare la password. Per tenere conto di questo, i siti Web che offrono account utente devono includere un modo per consentire a un utente di recuperare la password. Questo processo comporta in genere la generazione di una nuova password casuale e la posta elettronica all'indirizzo di posta elettronica dell'utente nel file. Dopo aver ricevuto la nuova password, la maggior parte degli utenti torna al sito e cambia la password da quella generata in modo casuale a una più memorabile.

ASP.NET include due controlli Web per agevolare il ripristino e la modifica delle password. Il controllo PasswordRecovery consente a un visitatore di recuperare la password persa. Il controllo ChangePassword consente all'utente di aggiornare la password. Analogamente agli altri controlli Web correlati all'accesso illustrati in questa serie di esercitazioni, i controlli PasswordRecovery e ChangePassword funzionano con il framework di appartenenza in background per reimpostare o modificare le password degli utenti.

In questa esercitazione si esaminerà l'uso di questi due controlli. Si vedrà anche come modificare e reimpostare a livello di codice la password di un utente tramite i metodi e ResetPassword della MembershipUser ChangePassword classe .

Passaggio 1: Aiutare gli utenti a recuperare le password perse

Tutti i siti Web che supportano gli account utente devono fornire agli utenti un meccanismo per recuperare le password dimenticate. La buona notizia è che l'implementazione di tali funzionalità in ASP.NET è una brezza grazie al controllo Web PasswordRecovery. Il controllo PasswordRecovery esegue il rendering di un'interfaccia che richiede all'utente il nome utente e, se necessario, la risposta alla domanda di sicurezza. Invia quindi messaggi di posta elettronica all'utente la password.

Nota

Poiché i messaggi di posta elettronica vengono trasmessi in transito in testo normale, esistono rischi per la sicurezza associati all'invio della password di un utente tramite posta elettronica.

Il controllo PasswordRecovery è costituito da tre visualizzazioni:

  • UserName : richiede al visitatore il nome utente. Si tratta della visualizzazione iniziale.
  • Domanda: visualizza il nome utente e la domanda di sicurezza dell'utente come testo, insieme a un controllo TextBox per consentire all'utente di immettere la risposta alla domanda di sicurezza.
  • Operazione riuscita: visualizza un messaggio che informa l'utente che la password è stata e-mail.

Le visualizzazioni visualizzate e le azioni eseguite dal controllo PasswordRecovery dipendono dalle impostazioni di configurazione dell'appartenenza seguenti:

  • RequiresQuestionAndAnswer
  • EnablePasswordRetrieval
  • EnablePasswordReset

L'impostazione del framework di RequiresQuestionAndAnswer appartenenza indica se gli utenti devono specificare una domanda di sicurezza e una risposta durante la registrazione per un account. Come illustrato nell'esercitazione Creazione di account utente, se RequiresQuestionAndAnswer è True (impostazione predefinita), l'interfaccia di CreateUserWizard include controlli TextBox per la domanda di sicurezza e la risposta del nuovo utente; se RequiresQuestionAndAnswer è False, non vengono raccolte tali informazioni. Analogamente, se RequiresQuestionAndAnswer è True, il controllo PasswordRecovery visualizza la visualizzazione Domanda dopo che l'utente ha immesso il proprio nome utente. La password viene ripristinata solo se l'utente immette la risposta di sicurezza corretta. Se RequiresQuestionAndAnswer è False, tuttavia, il controllo PasswordRecovery passa direttamente dalla visualizzazione UserName alla visualizzazione Operazione riuscita.

Dopo che l'utente ha fornito il proprio nome utente, o il nome utente e la risposta di sicurezza, se RequiresQuestionAndAnswer è True, passwordRecovery invia un messaggio di posta elettronica all'utente. Se l'opzione EnablePasswordRetrieval è impostata su True, l'utente invia tramite posta elettronica la password corrente. Se è impostata su False ed EnablePasswordReset è impostata su True, il controllo PasswordRecovery genera una nuova password casuale per l'utente e invia loro la nuova password. Se e EnablePasswordRetrieval EnablePasswordReset sono false, il controllo PasswordRecovery genera un'eccezione.

Nota

Tenere presente che le SqlMembershipProvider password degli utenti vengono archiviate in uno dei tre formati: Clear, Hashed (impostazione predefinita) o Encrypted. Il meccanismo di archiviazione usato dipende dalle impostazioni di configurazione dell'appartenenza; l'applicazione demo usa il formato della password con hash. Quando si usa il formato password con hash, l'opzione EnablePasswordRetrieval deve essere impostata su False perché il sistema non è in grado di determinare la password effettiva dell'utente dalla versione con hash archiviata nel database.

La figura 1 illustra come l'interfaccia e il comportamento di PasswordRecovery sono influenzati dalla configurazione di appartenenza.

RequiresQuestionAndAnswer, EnablePasswordRetrieval e EnablePasswordReset Influenzano l'aspetto e il comportamento del controllo PasswordRecovery

Figura 1: Aspetto RequiresQuestionAndAnswerEnablePasswordReset EnablePasswordRetrievale influenza l'aspetto e il comportamento del controllo PasswordRecovery (fare clic per visualizzare l'immagine a dimensione intera)

Nota

Nell'esercitazione Creazione dello schema di appartenenza in SQL Server è stato configurato il provider di appartenenze impostando su RequiresQuestionAndAnswer True, EnablePasswordRetrieval su False e EnablePasswordReset su True.

Uso del controllo PasswordRecovery

Si esaminerà ora l'uso del controllo PasswordRecovery in una pagina ASP.NET. Aprire RecoverPassword.aspx e trascinare un controllo PasswordRecovery dalla casella degli strumenti alla finestra di progettazione; impostarne il valore ID su RecoverPwd. Analogamente ai controlli Web Login e CreateUserWizard, le visualizzazioni del controllo PasswordRecovery eseguono il rendering di un'interfaccia composita avanzata che include etichette, caselle di testo, pulsanti e controlli di convalida. È possibile personalizzare l'aspetto delle visualizzazioni tramite le proprietà di stile del controllo o convertendo le visualizzazioni in modelli. Lascio questo come esercizio per il lettore interessato.

Quando un utente visita questa pagina, immetterà il nome utente e farà clic sul pulsante Invia. Poiché la RequiresQuestionAndAnswer proprietà è stata impostata su True nelle impostazioni di configurazione dell'appartenenza, il controllo PasswordRecovery visualizzerà quindi la visualizzazione Domanda. Dopo che l'utente immette la risposta di sicurezza corretta e fa clic su Invia, il controllo PasswordRecovery aggiornerà la password dell'utente a una password generata in modo casuale e invia la password all'indirizzo di posta elettronica nel file. Tutto questo è stato possibile senza dover scrivere una singola riga di codice!

Prima di testare questa pagina, è necessario specificare le impostazioni di recapito della posta elettronica in Web.config. Il controllo PasswordRecovery si basa su queste impostazioni per l'invio del messaggio di posta elettronica.

La configurazione per il recapito della posta viene specificata tramite l'elemento dell'elemento<mailSettings> .<system.net> Utilizzare l'elemento <smtp> per indicare il metodo di recapito e l'indirizzo From predefinito. Il markup seguente configura le impostazioni di posta elettronica per l'uso di un server SMTP di rete denominato smtp.example.com sulla porta 25 e con credenziali nome utente/password di nome utente e password.

Nota

<system.net> è un elemento figlio dell'elemento radice <configuration> e un elemento di pari livello di <system.web>. Pertanto, non inserire l'elemento <system.net> all'interno dell'elemento <system.web> , ma inserirlo allo stesso livello.

<configuration>
 ...
 <system.net>
 <mailSettings>
 <smtp deliveryMethod="Network" from="youraddress@example.com">
 <network
 host="smtp.example.com"
 userName="username"
 password="password"
 port="25" />
 </smtp>
 </mailSettings>
 </system.net>
</configuration>

Oltre a utilizzare un server SMTP in rete, è possibile specificare in alternativa una directory di ritiro in cui inviare i messaggi di posta elettronica da inviare.

Dopo aver configurato le impostazioni SMTP, visitare la RecoverPassword.aspx pagina tramite un browser. Provare prima di tutto a immettere un nome utente che non esiste nell'archivio utenti. Come illustrato nella figura 2, il controllo PasswordRecovery visualizza un messaggio che indica che non è stato possibile accedere alle informazioni utente. Il testo del messaggio può essere personalizzato tramite la proprietà del UserNameFailureText controllo.

Viene visualizzato un messaggio di errore se viene immesso un nome utente non valido

Figura 2: Viene visualizzato un messaggio di errore se viene immesso un nome utente non valido (fare clic per visualizzare l'immagine a dimensione intera)

Immettere ora un nome utente. Usare il nome utente di un account nel sistema con un indirizzo di posta elettronica accessibile e la cui risposta di sicurezza si conosce. Dopo aver immesso il nome utente e aver fatto clic su Invia, il controllo PasswordRecovery visualizza la visualizzazione Domanda. Come per la visualizzazione UserName, se si immette una risposta errata, il controllo PasswordRecovery visualizza un messaggio di errore (vedere la figura 3). Utilizzare la QuestionFailureText proprietà per personalizzare questo messaggio di errore.

Viene visualizzato un messaggio di errore se l'utente immette una risposta di sicurezza non valida

Figura 3: Viene visualizzato un messaggio di errore se l'utente immette una risposta di sicurezza non valida (fare clic per visualizzare l'immagine a dimensione intera)

Immettere infine la risposta di sicurezza corretta e fare clic su Invia. Dietro le quinte, il controllo PasswordRecovery genera una password casuale, la assegna all'account utente, invia un messaggio di posta elettronica che informa l'utente della nuova password (vedere la figura 4) e quindi visualizza la visualizzazione Operazione riuscita.

L'utente viene inviato un messaggio di posta elettronica con la nuova password

Figura 4: L'utente viene inviato un messaggio di posta elettronica con la nuova password (fare clic per visualizzare l'immagine a dimensione intera)

Personalizzazione del messaggio di posta elettronica

Il messaggio di posta elettronica predefinito inviato dal controllo PasswordRecovery è piuttosto noioso (vedere la figura 4). Il messaggio viene inviato dall'account specificato nell'attributo <smtp> dell'elemento from con l'oggetto Password e il corpo del testo normale:

Tornare al sito e accedere usando le informazioni seguenti.

Nome utente: nome utente

Password: password

Questo messaggio può essere personalizzato a livello di codice tramite un gestore eventi per l'evento del controllo PasswordRecovery o in modo dichiarativo tramite la MailDefinition proprietà .SendingMail Verranno ora esaminate entrambe queste opzioni.

L'evento SendingMail viene generato subito prima dell'invio del messaggio di posta elettronica ed è l'ultima possibilità di modificare a livello di codice il messaggio di posta elettronica. Quando viene generato questo evento, il gestore eventi viene passato a un oggetto di tipo MailMessageEventArgs, la cui Message proprietà contiene un riferimento al messaggio di posta elettronica che sta per essere inviato.

Creare un gestore eventi per l'evento SendingMail e aggiungere il codice seguente, che aggiunge webmaster@example.com a livello di codice all'elenco CC.

Protected Sub RecoverPwd_SendingMail(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.MailMessageEventArgs)Handles RecoverPwd.SendingMail
 e.Message.CC.Add("webmaster@example.com")
End Sub

Il messaggio di posta elettronica può essere configurato anche tramite mezzi dichiarativi. La proprietà di MailDefinition PasswordRecovery è un oggetto di tipo MailDefinition. La MailDefinition classe offre un host di proprietà correlate alla posta elettronica, tra cui From, CC, SubjectPriorityIsBodyHtml, BodyFileNamee altre. Per iniziare, impostare la Subject proprietà su qualcosa di più descrittivo di quello usato per impostazione predefinita ( Password ), ad esempio La password è stata reimpostata...

Per personalizzare il corpo del messaggio di posta elettronica, è necessario creare un file modello di posta elettronica separato che contiene il contenuto del corpo. Per iniziare, creare una nuova cartella nel sito Web denominato EmailTemplates. Aggiungere quindi un nuovo file di testo a questa cartella denominata PasswordRecovery.txt e aggiungere il contenuto seguente:

Your password has been reset, <%UserName%>!

According to our records, you have requested that your password be reset. Your new
password is: <%Password%>

If you have any questions or trouble logging on please contact a site administrator.

Thank you!

Si noti l'uso dei segnaposto <%UserName%> e <%Password%>di . Il controllo PasswordRecovery sostituisce automaticamente questi due segnaposto con il nome utente dell'utente e la password ripristinata prima di inviare il messaggio di posta elettronica.

Infine, puntare la MailDefinitionproprietà della proprietà al modello di BodyFileName posta elettronica appena creato (~/EmailTemplates/PasswordRecovery.txt).

Dopo aver apportato queste modifiche, rivedere la RecoverPassword.aspx pagina e immettere il nome utente e la risposta di sicurezza. Si riceverà un messaggio di posta elettronica simile a quello nella figura 5. Si noti che webmaster@example.com è stato CC'd e che l'oggetto e il corpo sono stati aggiornati.

L'oggetto, il corpo e l'elenco CC sono stati aggiornati

Figura 5: L'oggetto, il corpo e l'elenco CC sono stati aggiornati (fare clic per visualizzare l'immagine a dimensione intera)

Per inviare un messaggio di posta elettronica in formato HTML impostato su IsBodyHtml True (il valore predefinito è False) e aggiornare il modello di posta elettronica in modo da includere HTML.

La MailDefinition proprietà non è univoca per la classe PasswordRecovery. Come vedremo nel passaggio 2, il controllo ChangePassword offre anche una MailDefinition proprietà. Inoltre, il controllo CreateUserWizard include tale proprietà che è possibile configurare per inviare automaticamente un messaggio di posta elettronica di benvenuto ai nuovi utenti.

Nota

Attualmente non sono presenti collegamenti nel riquadro di spostamento a sinistra per raggiungere la RecoverPassword.aspx pagina. Un utente potrebbe essere interessato a visitare questa pagina solo se non è riuscito ad accedere correttamente al sito. Aggiornare quindi la Login.aspx pagina in modo da includere un collegamento alla RecoverPassword.aspx pagina.

Reimpostazione della password di un utente a livello di codice

Quando si reimposta la password di un utente, il controllo PasswordRecovery chiama il MembershipUser metodo dell'oggettoResetPassword. Questo metodo presenta due overload:

  • ResetPassword : reimposta la password di un utente. Usare questo overload se RequiresQuestionAndAnswer è False.
  • ResetPassword(securityAnswer)- reimposta la password di un utente solo se la sicurezza fornitaAnswer è corretta. Usare questo overload se RequiresQuestionAndAnswer è True.

Entrambi gli overload restituiscono la nuova password generata in modo casuale.

Analogamente agli altri metodi nel framework di appartenenza, il ResetPassword metodo delega al provider configurato. SqlMembershipProvider Richiama la aspnet_Membership_ResetPassword stored procedure, passando il nome utente dell'utente, la nuova password e la risposta della password fornita, tra gli altri campi. La stored procedure garantisce che la risposta alla password corrisponda e quindi aggiorni la password dell'utente.

Un paio di note di implementazione di basso livello:

  • Un utente bloccato non può reimpostare la password. Tuttavia, un utente non approvato può. Verranno illustrati in dettaglio gli stati bloccati e approvati nell'esercitazione Sblocco e approvazione degli account utente .
  • Se la risposta alla password non è corretta, il numero di tentativi di risposta password non riusciti dell'utente viene incrementato. Se un numero specificato di tentativi di risposta di sicurezza non validi si verifica entro un intervallo di tempo specificato, l'utente viene bloccato.

Una parola su come vengono generate le password casuali

Le password generate in modo casuale visualizzate nei messaggi di posta elettronica nelle figure 4 e 5 vengono create dal metodo della GeneratePassword classe Membership. Questo metodo accetta due parametri di input integer, length e numberOfNonAlphanumericCharacters, e restituisce una stringa di almeno lunghezza di caratteri con almeno numberOfNonAlphanumericCharacters numero di caratteri non alfanumerici. Quando questo metodo viene chiamato dall'interno delle classi Membership o dai controlli Web correlati all'account di accesso, i valori per questi due parametri sono determinati rispettivamente dalle proprietà e MinRequiredNonalphanumericCharacters della MinRequiredPasswordLength configurazione Membership, impostate rispettivamente su 7 e 1.

Il GeneratePassword metodo usa un generatore di numeri casuali crittograficamente sicuri per garantire che non vi siano distorsioni nei caratteri casuali selezionati. Inoltre, GeneratePassword è Public, vale a dire che è possibile usarlo direttamente dall'applicazione ASP.NET se è necessario generare stringhe o password casuali.

Nota

La SqlMembershipProvider classe genera sempre una password casuale di almeno 14 caratteri, quindi se MinRequiredPasswordLength è minore di 14, il valore viene ignorato.

Passaggio 2: Modifica delle password

Le password generate in modo casuale sono difficili da ricordare. Si consideri la password illustrata nella figura 4: WWGUZv(f2yM:Bd. Prova a eseguire il commit in memoria! Inutile dire, dopo che un utente viene inviato una password generata in modo casuale di questo tipo, vuole modificare la password in modo più memorabile.

Usare il controllo ChangePassword per creare un'interfaccia per consentire a un utente di modificare la password. Analogamente al controllo PasswordRecovery, il controllo ChangePassword è costituito da due visualizzazioni: Cambia password e Operazione riuscita. La visualizzazione Cambia password richiede all'utente le password precedenti e nuove. Quando si specifica la password precedente corretta e una nuova password che soddisfa i requisiti minimi di lunghezza e carattere non alfanumerico, il controllo ChangePassword aggiorna la password dell'utente e visualizza la visualizzazione Operazione riuscita.

Nota

Il controllo ChangePassword modifica la password dell'utente richiamando il MembershipUser metodo dell'oggettoChangePassword. Il metodo ChangePassword accetta due String parametri di input, oldPassword e newPassword, e aggiorna l'account dell'utente con newPassword, presupponendo che oldPassword fornito sia corretto.

Aprire la ChangePassword.aspx pagina e aggiungere un controllo ChangePassword alla pagina, denominandolo ChangePwd. A questo punto, la visualizzazione Struttura dovrebbe mostrare la visualizzazione Cambia password (vedere la figura 6). Analogamente al controllo PasswordRecovery, è possibile alternare le visualizzazioni tramite smart tag del controllo. Inoltre, queste visualizzazioni sono personalizzabili tramite le proprietà di stile diverse o convertendole in un modello.

Aggiungere un controllo ChangePassword alla pagina

Figura 6: Aggiungere un controllo ChangePassword alla pagina (fare clic per visualizzare l'immagine a dimensione intera)

Il controllo ChangePassword può aggiornare la password dell'utente attualmente connesso o la password di un altro utente specificato. Come illustrato nella figura 6, la visualizzazione modifica password predefinita esegue il rendering di soli tre controlli TextBox: uno per la vecchia password e due per la nuova password. Questa interfaccia predefinita viene usata per aggiornare la password dell'utente attualmente connesso.

Per utilizzare il controllo ChangePassword per aggiornare la password di un altro utente, impostare la proprietà del DisplayUserName controllo su True. In questo modo viene aggiunto un quarto controllo TextBox alla pagina, che richiede il nome utente dell'utente la cui password deve cambiare.

L'impostazione DisplayUserName su True è utile se si vuole consentire a un utente disconnesso di modificare la password senza dover accedere. Personalmente, penso che non ci sia nulla di sbagliato con la richiesta di un utente di accedere prima di consentire a lei di modificare la password. Lasciare DisplayUserName quindi impostato su False (impostazione predefinita). Nel prendere questa decisione, tuttavia, si impedisce agli utenti anonimi di raggiungere questa pagina. Aggiornare le regole di autorizzazione URL del sito in modo da impedire agli utenti anonimi di visitare ChangePassword.aspx. Se è necessario aggiornare la memoria nella sintassi della regola di autorizzazione URL, fare riferimento all'esercitazione sull'autorizzazione basata sull'utente.

Nota

Può sembrare che la DisplayUserName proprietà sia utile per consentire agli amministratori di modificare le password di altri utenti. Tuttavia, anche se DisplayUserName è impostato su True, la vecchia password corretta deve essere nota e immessa. Verranno illustrate le tecniche per consentire agli amministratori di modificare le password degli utenti nel passaggio 3.

Visitare la ChangePassword.aspx pagina tramite un browser e modificare la password. Si noti che viene visualizzato un messaggio di errore se si immette una nuova password che non soddisfa i requisiti relativi alla lunghezza della password e ai caratteri non alfanumerici specificati nella configurazione di appartenenza (vedere la figura 7).

Viene visualizzato un messaggio di errore se si immette una nuova password che non soddisfa i requisiti di lunghezza della password e caratteri non alfanumerici.

Figura 7: Aggiungere un controllo ChangePassword alla pagina (fare clic per visualizzare l'immagine a dimensione intera)

Dopo aver immesso la password precedente corretta e una nuova password valida, la password dell'utente connesso viene modificata e viene visualizzata la visualizzazione Operazione riuscita.

Invio di un messaggio di posta elettronica di conferma

Per impostazione predefinita, il controllo ChangePassword non invia un messaggio di posta elettronica all'utente la cui password è stata appena aggiornata. Se si vuole inviare un messaggio di posta elettronica, è sufficiente configurare la proprietà del MailDefinition controllo. Configurare il controllo ChangePassword in modo che l'utente venga inviato un messaggio di posta elettronica in formato HTML contenente la nuova password.

Per iniziare, creare un nuovo file nella EmailTemplates cartella denominata ChangePassword.htm. Aggiungere il markup seguente:

<html>
 <body>
 <h2>Your Password Has Been Changed!</h2>
 <p>
 This email confirms that your password has been changed.
 </p>
 <p>
 To log on to the site, use the following credentials:
 </p>
 <table>
 <tr>
 <td>
 <b>Username:</b>
 </td>
 <td>
 <%UserName%>
 </td>
 </tr>
 <tr>
 <td>
 <b>Password:</b>
 </td>
 <td>
 <%Password%>
 </td>
 </tr>
 </table>
 <p>
 If you have any questions or encounter any problems logging in,
 please contact a site administrator.
 </p>
 </body>
</html>

Impostare quindi le proprietà , IsBodyHtmle Subject della proprietà del MailDefinition BodyFileNamecontrollo ChangePassword su ~/EmailTemplates/ChangePassword.htm, True e La password è stata modificata rispettivamente.

Dopo aver apportato queste modifiche, rivedere la pagina e modificare nuovamente la password. Questa volta, il controllo ChangePassword invia un messaggio di posta elettronica personalizzato in formato HTML all'indirizzo di posta elettronica dell'utente nel file (vedere la figura 8).

Un messaggio di posta elettronica informa l'utente che la password è stata modificata

Figura 8: Un messaggio di posta elettronica informa l'utente che la password è stata modificata (fare clic per visualizzare l'immagine a dimensione intera)

Passaggio 3: Consentire agli amministratori di modificare le password degli utenti

Una funzionalità comune nelle applicazioni che supportano gli account utente è la possibilità per un utente amministratore di modificare le password di altri utenti. A volte questa funzionalità è necessaria perché il sistema non ha la possibilità per gli utenti di modificare le proprie password. In questo caso, l'unico modo per recuperare la password dimenticata da un utente consiste nell'assegnare una nuova password all'amministratore. Con i controlli PasswordRecovery e ChangePassword, tuttavia, gli utenti amministratori non devono impegnarsi con la modifica delle password degli utenti, in quanto gli utenti sono in grado di eseguire questa operazione autonomamente.

Ma cosa succede se il client insiste sul fatto che gli utenti amministratori debbano essere in grado di modificare le password di altri utenti? Sfortunatamente, l'aggiunta di questa funzionalità può essere un po ' di lavoro. Per modificare la password di un utente, è necessario fornire la password precedente e nuova al MembershipUser metodo dell'oggetto ChangePassword , ma un amministratore non deve conoscere la password di un utente per modificarla.

Una soluzione alternativa consiste nel reimpostare prima la password dell'utente e quindi modificarla alla nuova password usando codice simile al seguente:

Dim usr As MembershipUser = Membership.GetUser(username)
Dim resetPwd As String = usr.ResetPassword()
usr.ChangePassword(resetPwd, newPassword)

Questo codice inizia recuperando informazioni sul nome utente, ovvero l'utente la cui password l'amministratore desidera modificare. Viene quindi richiamato il ResetPassword metodo , che assegna e l'utente una nuova password casuale. Questa password generata in modo casuale viene restituita dal metodo e archiviata nella variabile resetPwd. Ora che si conosce la password dell'utente, è possibile modificarla tramite una chiamata a ChangePassword.

Il problema è che questo codice funziona solo se la configurazione del sistema di appartenenza è impostata in modo che RequiresQuestionAndAnswer sia False. Se RequiresQuestionAndAnswer è True, come accade con l'applicazione, il ResetPassword metodo deve essere passato alla risposta di sicurezza. In caso contrario, genererà un'eccezione.

Se il framework di appartenenza è configurato per richiedere una domanda e una risposta di sicurezza, ma il client insiste che gli amministratori possano modificare le password degli utenti, sono disponibili tre opzioni:

  • Buttare le mani in aria e dire al cliente che questa è solo una cosa che non può essere fatto.
  • Impostare su RequiresQuestionAndAnswer False. Ciò comporta un'applicazione meno sicura. Si supponga che un utente nefarioso abbia ottenuto l'accesso alla posta in arrivo di un altro utente. Forse l'utente compromesso ha lasciato la scrivania per andare a pranzo e non ha bloccato la workstation, o forse ha eseguito l'accesso alla posta elettronica da un terminale pubblico e non ha disconnesso. In entrambi i casi, l'utente nefarioso può visitare la RecoverPassword.aspx pagina e immettere il nome utente dell'utente. Il sistema invia quindi un messaggio di posta elettronica alla password ripristinata senza richiedere la risposta di sicurezza.
  • Ignorare il livello di astrazione creato dal framework di appartenenza e lavorare direttamente con il database di SQL Server. Lo schema Di appartenenza include una stored procedure denominata aspnet_Membership_SetPassword che imposta la password di un utente e non richiede la risposta di sicurezza o la vecchia password per eseguire l'attività.

Nessuna di queste opzioni è particolarmente attraente, ma questo è il modo in cui la vita di uno sviluppatore va a volte.

Sono andato avanti e implementato il terzo approccio, scrivendo codice che ignora le Membership classi e MembershipUser e opera direttamente sul SecurityTutorials database.

Nota

Lavorando direttamente con il database, l'incapsulamento fornito dal framework di appartenenza viene distrutto. Questa decisione ci collega a , rendendo il SqlMembershipProvidercodice meno portabile. Inoltre, questo codice potrebbe non funzionare come previsto nelle versioni future di ASP.NET se lo schema di appartenenza cambia. Questo approccio è una soluzione alternativa e, come la maggior parte delle soluzioni alternative, non è un esempio di procedure consigliate.

Il codice ha alcuni bit non attraenti ed è piuttosto lungo. Pertanto, non voglio ingombrare questo tutorial con un esame approfondito di esso. Per altre informazioni, scaricare il codice per questa esercitazione e visitare la ~/Administration/ManageUsers.aspx pagina. Questa pagina, creata nell'esercitazione precedente, elenca ogni utente. Ho aggiornato GridView per includere un collegamento alla UserInformation.aspx pagina, passando il nome utente dell'utente selezionato tramite la stringa di query. Nella UserInformation.aspx pagina vengono visualizzate informazioni sull'utente selezionato e sui caselle di testo per la modifica della password (vedere la figura 9).

Dopo aver immesso la nuova password, confermarla nel secondo controllo TextBox e fare clic sul pulsante Aggiorna utente, viene eseguito un postback e viene richiamata la aspnet_Membership_SetPassword stored procedure, aggiornando la password dell'utente. Invito i lettori interessati a questa funzionalità a acquisire maggiore familiarità con il codice e provare a estendere la funzionalità per includere l'invio di un messaggio di posta elettronica all'utente la cui password è stata modificata.

Un amministratore può modificare la password di un utente

Figura 9: Un amministratore può modificare la password di un utente (fare clic per visualizzare l'immagine a dimensione intera)

Nota

La UserInformation.aspx pagina funziona attualmente solo se il framework di appartenenza è configurato per archiviare le password in formato Cancella o Hash. Manca il codice per crittografare la nuova password, anche se si è invitati ad aggiungere questa funzionalità. Il modo in cui è consigliabile aggiungere il codice necessario consiste nell'usare un decompiler come Reflector per esaminare il codice sorgente per i metodi in .NET Framework. Per iniziare, esaminare il SqlMembershipProvider metodo della ChangePassword classe. Questa è la tecnica usata per scrivere il codice per creare un hash della password.

Riepilogo

ASP.NET offre due controlli che consentono agli utenti di gestire la password. Il controllo PasswordRecovery è utile per coloro che hanno dimenticato le password. A seconda della configurazione del framework di appartenenza, l'utente invia tramite posta elettronica la password esistente o una nuova password generata in modo casuale. Il controllo ChangePassword consente a un utente di aggiornare la password.

Analogamente ai controlli Login e CreateUserWizard, i controlli PasswordRecovery e ChangePassword eseguono il rendering di un'interfaccia utente avanzata senza dover scrivere un tocco di markup dichiarativo o riga di codice. Se l'interfaccia utente predefinita non soddisfa le proprie esigenze, è possibile personalizzarla tramite un'ampia gamma di proprietà di stile. In alternativa, le interfacce dei controlli possono essere convertite in modelli, per un grado di controllo ancora più fine. In background questi controlli usano l'API Membership, richiamando i MembershipUser metodi e ChangePassword dell'oggettoResetPassword.

Buon programmatori!

Altre informazioni

Per altre informazioni sugli argomenti illustrati in questa esercitazione, vedere le risorse seguenti:

Informazioni sull'autore

Scott Mitchell, autore di più libri ASP/ASP.NET e fondatore di 4GuysFromRolla.com, ha lavorato con le tecnologie Web Microsoft dal 1998. Scott lavora come consulente indipendente, formatore e scrittore. Il suo ultimo libro è Sams Teach Yourself ASP.NET 2.0 in 24 ore. Scott può essere raggiunto all'indirizzo mitchell@4guysfromrolla.com o tramite il suo blog all'indirizzo http://ScottOnWriting.NET.

Grazie speciale a

Questa serie di esercitazioni è stata esaminata da molti revisori utili. I revisori potenziali per questa esercitazione includono Michael Emmings e Suchi Banerjee. Si è interessati a esaminare i prossimi articoli MSDN? In tal caso, lasciami una riga in mitchell@4GuysFromRolla.com