Want to protect your cyber security and still get fast solutions? Ask a secure question today.Go Premium


Pre-fill in password field

Posted on 2007-03-27
Medium Priority
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 1000 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

Become an Android App Developer

Ready to kick start your career in 2018? Learn how to build an Android app in January’s Course of the Month and open the door to new opportunities.

Question has a verified solution.

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

Entity Framework is a powerful tool to help you interact with the DataBase but still doesn't help much when we have a Stored Procedure that returns more than one resultset. The solution takes some of out-of-the-box thinking; read on!
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…
When cloud platforms entered the scene, users and companies jumped on board to take advantage of the many benefits, like the ability to work and connect with company information from various locations. What many didn't foresee was the increased risk…
Enter Foreign and Special Characters Enter characters you can't find on a keyboard using its ASCII code ... and learn how to make a handy reference for yourself using Excel ~ Use these codes in any Windows application! ... whether it is a Micr…
Suggested Courses
Course of the Month10 days, 18 hours left to enroll

571 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