Want to win a PS4? Go Premium and enter to win our High-Tech Treats giveaway. Enter to Win


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
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 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

What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

Question has a verified solution.

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

IntroductionWhile developing web applications, a single page might contain many regions and each region might contain many number of controls with the capability to perform  postback. Many times you might need to perform some action on an ASP.NET po…
Problem Hi all,    While many today have fast Internet connection, there are many still who do not, or are connecting through devices with a slower connect, so light web pages and fast load times are still popular.    If your ASP.NET page …
How to fix incompatible JVM issue while installing Eclipse While installing Eclipse in windows, got one error like above and unable to proceed with the installation. This video describes how to successfully install Eclipse. How to solve incompa…
This lesson discusses how to use a Mainform + Subforms in Microsoft Access to find and enter data for payments on orders. The sample data comes from a custom shop that builds and sells movable storage structures that are delivered to your property. …

618 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