Pre-fill in password field

Posted on 2007-03-27
Last Modified: 2013-11-07
I have a page that accepts a useraname/password combination for a connection.  This is then stored with some other settings (yes it is encrypted).

If a site admin goes to the management page, they should be able to change various site settings, along with the above mentioned username/pasword if desired.

But if they do not want to change the username/password then I would like them to leave those fields alone.  If the field was a normal textbox field this works fine.  But we wanted to make the field a password field, so an admin casually browsing to the settings page would not see the password - just ********

However, as soon as you make this a password field (textmode="password") then it no longer fills in from the code behind.

This causes a problem, because when the page is then saved - if another setting was changed, it flushes the password.

It also is not a viable option to have the admin type in the password for this connection each time they want to make any of the other changes to the page.

Any ideas on how to be able to default fill in the password from the saved value?
Question by:mrichmon
  • 2

Accepted Solution

mzalewski earned 250 total points
ID: 18803541
The problem with a pre-filled password field is that the actual value of the field is stored in plain text in the HTML source (Unless something like Javascript is used to fill it in). This means anyone can go to View Source and see what the current password is.
You can see what kind of security problems this would create if people started created websites etc unaware that the password was actually being sent to the browser in plain text.

It's not even possible to set the value programmatically - it still displays blank.

If you still want the password pre-filled, the easiest solution would be to use javascript to autofill the password field when the page loads.
Other solutions:
Use a normal Textbox, and use javascript to change it's 'type' attribute to 'password' on page load.
Find an alternative ASP.NET control on the internet.
Create your own custom control that allows you to do this.

If you are posting back to the same page, and you want the password field to appear 'filled in' then I'd suggest storing the password in a session variable (to keep it on the server), and using javascript to fill the password box with 0's.
When the page is posted back, the server can check to see if the password has been changed (ie: doesnt contain 0's), and either use the new password, or retrieve the old one from session.

This way, the password is not being sent over the internet, the user 'sees' the password box filled in, and the password can still be changed if needed
LVL 35

Author Comment

ID: 18803923
>>This means anyone can go to View Source and see what the current password is.
Yes I realize that, but they can do that as well if I use a regular text box.  In fact, you can get the password of any password field using javascript regardless of how it was set.

>>I'd suggest storing the password in a session variable (to keep it on the server)
Won't work.

>>This way, the password is not being sent over the internet
It is when it is set/changed anyway.  That is what other security measures are for...

>>the easiest solution would be to use javascript to autofill the password field when the page loads.
That actually presents other issues that I don't particularly like.

>>Use a normal Textbox, and use javascript to change it's 'type' attribute to 'password' on page load.
This is the only thing I was able to come up with on my own and had put in place for now while I waited to see if anyone came up with any other ideas.

The only other thing was to have some other indicator saying the password was changing - like making the user check a box that says something like "Update Password", but I didn't like that too much either...

Thanks for the input so far...

Expert Comment

ID: 18804129
Ok, here is a class I just created:
namespace CustomWebControls
    public class TextBox : System.Web.UI.WebControls.TextBox
        protected override void AddAttributesToRender(HtmlTextWriter writer)
            if (this.TextMode == TextBoxMode.Password)
                Page page = this.Page;
                if (page != null)
                string uniqueID = this.UniqueID;
                if (uniqueID != null)
                    writer.AddAttribute(HtmlTextWriterAttribute.Name, uniqueID);

                    writer.AddAttribute(HtmlTextWriterAttribute.Type, "password");
                    // Added this here:
                    string text = this.Text;
                    if (text.Length > 0)
                        writer.AddAttribute(HtmlTextWriterAttribute.Value, text);
                    int maxLength = this.MaxLength;
                    if (maxLength > 0)
                        writer.AddAttribute(HtmlTextWriterAttribute.Maxlength, maxLength.ToString(NumberFormatInfo.InvariantInfo));
                    maxLength = this.Columns;
                    if (maxLength > 0)
                        writer.AddAttribute(HtmlTextWriterAttribute.Size, maxLength.ToString(NumberFormatInfo.InvariantInfo));
            } else {
                // If Textmode != Password

2 - Compile it, place the dll in your websites bin folder

3 - Register it in your ASPX
<%@ Register Namespace="CustomWebControls" Assembly="CustomWebControls"  TagPrefix="CWC" %>

4 - Add the control to the page
<CWC:TextBox runat="server" TextMode="Password" Text="Hello123" />

Hopefully, this example will help anyone else who is looking to pre-fill a password box. It inherits the TextBox, so it should behave the same way. The only thing that won't work is the AutoPostback OnChange event (I hope thats the only thing). This can be easily added though.

I used Reflector to disassemble the .NET 2.0 TextBox, so it should be pretty close. For other TextModes, it just uses the base method.

It would have been easier to modify the "type" attribute after base.OnRenderAttributes is executed, but I don't know any easy way to do this.

Featured Post

DevOps Toolchain Recommendations

Read this Gartner Research Note and discover how your IT organization can automate and optimize DevOps processes using a toolchain architecture.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Loop not working 29 47
IIS issues - Convert to Application - APS.NET v4.0 3 23
Exit the loop 4 37
Code works but it's slow 24 44
Today I had a very interesting conundrum that had to get solved quickly. Needless to say, it wasn't resolved quickly because when we needed it we were very rushed, but as soon as the conference call was over and I took a step back I saw the correct …
Real-time is more about the business, not the technology. In day-to-day life, to make real-time decisions like buying or investing, business needs the latest information(e.g. Gold Rate/Stock Rate). Unlike traditional days, you need not wait for a fe…
This Micro Tutorial hows how you can integrate  Mac OSX to a Windows Active Directory Domain. Apple has made it easy to allow users to bind their macs to a windows domain with relative ease. The following video show how to bind OSX Mavericks to …
Windows 10 is mostly good. However the one thing that annoys me is how many clicks you have to do to dial a VPN connection. You have to go to settings from the start menu, (2 clicks), Network and Internet (1 click), Click VPN (another click) then fi…

896 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

18 Experts available now in Live!

Get 1:1 Help Now