Membership data in the ASP.NET database stores user names, emails, and a little other information, but I need to add more... All I want is a few additional columns added to the user's data, like their real name, phone/fax/cell numbers, etc. I don't want to go to the trouble of creating a SQL Server table and managing all the relationships to do this and then creating the SQL to fish that all up in my code.
Well, as it turns out that's exactly what the ProfileCommon object does.
There are a number of uncommonly pleasant surprises when you dig into this feature, so let's get started!
This article assumes you're using an aspnet default database setup created as in this article.
Ok try this: In your code pages, type
Profile.
: you will see a hint showing the options available.Profile Context Help yes you can stretch the pop-up box! |
web.config
file. Look for the end of the system.web
section. Insert the following lines.<profile defaultProvider="ProfileProvider"> <providers> <clear/> <add connectionStringName="ConnectionString" applicationName="/" name="ProfileProvider" type="System.Web.Profile.SqlProfileProvider"/> </providers> <properties> <add name="email_verified" allowAnonymous="false" type="System.Boolean"/> <add name="subscribed" allowAnonymous="false" type="System.Boolean"/> <add name="MemberID" allowAnonymous="false" type="System.String"/> <add name="FullName" allowAnonymous="false" type="System.String"/> </properties> </profile>OK, obviously your connection string has to be changed to match the one in your Membership and Roles provider. Look at the profile section. The editor doesn't help much with creating these types, but they are not hard to figure out.
All you need to do is create whatever columns you want to add. Then once they are added here, go back to your C# code and type Profile. again.
Notice that the added properties are now available to you to use in your programming. You can display then onscreen, let people edit them, even modify them in your code.
The Profile
object is of type ProfileCommon
, and is automatically instantiated when your page is loaded. Here are a few shortcuts for using it.
Use the logged-in user's Profile | Profile.[fieldname] |
Look up another user's Profile | ProfileCommon otherProfile = Profile.GetProfile(otherUSerName); |