Thursday, 6 November 2014

MySQL Connector/Net ASP.NET Membership and Role Provider


Many web sites feature the facility for the user to create a user account. They can then log into the web site and enjoy a personalized experience. This requires that the developer creates database tables to store user information, along with code to gather and process this data. This represents a burden on the developer, and there is the possibility for security issues to creep into the developed code. However, ASP.NET 2.0 introduced the Membership system. This system is designed around the concept of Membership, Profile and Role Providers, which together provide all of the functionality to implement a user system, that previously would have to have been created by the developer from scratch.
Currently, MySQL Connector/Net provides Membership, Role, Profile and Session State Providers.
This tutorial shows you how to set up your ASP.NET web application to use the MySQL Connector/Net Membership and Role Providers. It assumes that you have MySQL Server installed, along with MySQL Connector/Net and Microsoft Visual Studio. This tutorial was tested with MySQL Connector/Net 6.0.4 and Microsoft Visual Studio 2008 Professional Edition. It is recommended you use 6.0.4 or above for this tutorial.
  1. Create a new database in the MySQL Server using the MySQL Command-Line Client program (mysql), or other suitable tool. It does not matter what name is used for the database, but record it. You specify it in the connection string constructed later in this tutorial. This database contains the tables, automatically created for you later, used to store data about users and roles.
  2. Create a new ASP.NET Web Site in Visual Studio. If you are not sure how to do this, refer to Section 5.8, “Tutorial: Databinding in ASP.NET Using LINQ on Entities”, which demonstrates how to create a simple ASP.NET web site.
  3. Add References to MySql.Data and MySql.Web to the web site project.
  4. Locate the machine.config file on your system, which is the configuration file for the .NET Framework.
  5. Search the machine.config file to find the membership provider MySQLMembershipProvider.
  6. Add the attribute autogenerateschema="true". The appropriate section should now resemble the following (note: for the sake of brevity some information has been excluded):
    <membership>
     <providers>
       <add name="AspNetSqlMembershipProvider" 
         type="System.Web.Security.SqlMembershipProvider" 
         ... 
         connectionStringName="LocalSqlServer" 
         ... />
       <add name="MySQLMembershipProvider" 
         autogenerateschema="true" 
         type="MySql.Web.Security.MySQLMembershipProvider, MySql.Web, Version=6.0.4.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d" 
         connectionStringName="LocalMySqlServer" 
         ... />
     </providers>
    </membership>
    
    Note that the name for the connection string to be used to connect to the server that contains the membership database is LocalMySqlServer.
    The autogenerateschema="true" attribute will cause MySQL Connector/Net to silently create, or upgrade, the schema on the database server, to contain the required tables for storing membership information.
  7. It is now necessary to create the connection string referenced in the previous step. Load the web site'sweb.config file into Visual Studio.
  8. Locate the section marked <connectionStrings>. Add the following connection string information:
    <connectionStrings>
      <remove name="LocalMySqlServer"/>
      <add name="LocalMySqlServer"
           connectionString="Datasource=localhost;Database=users;uid=root;pwd=password;"
           providerName="MySql.Data.MySqlClient"/>
    </connectionStrings>
    
    The database specified is the one created in the first step. You could alternatively have used an existing database.
  9. At this point build the solution to ensure no errors are present. This can be done by selecting Build,Build Solution from the main menu, or pressing F6.
  10. ASP.NET supports the concept of locally and remotely authenticated users. With local authentication the user is validated using their Windows credentials when they attempt to access the web site. This can be useful in an Intranet environment. With remote authentication, a user is prompted for their login details when accessing the web site, and these credentials are checked against the membership information stored in a database server such as MySQL Server. You will now see how to choose this form of authentication.
    Start the ASP.NET Web Site Administration Tool. This can be done quickly by clicking the small hammer/Earth icon in the Solution Explorer. You can also launch this tool by selecting WebsiteASP.NET Configurationfrom the main menu.
  11. In the ASP.NET Web Site Administration Tool click the Security tab.
  12. Now click the User Authentication Type link.
  13. Select the From the internet radio button. The web site will now need to provide a form to allow the user to enter their login details. These will be checked against membership information stored in the MySQL database.
    Figure 5.2 Authentication Type
    Authentication Type
  14. You now need to specify the Role and Membership Provider to be used. Click the Provider tab.
  15. Click the Select a different provider for each feature (advanced) link.
  16. Now select the MySQLMembershipProvider and the MySQLRoleProvider radio buttons.
    Figure 5.3 Select Membership and Role Provider
    Select Membership and Role Provider
  17. In Visual Studio, rebuild the solution by selecting BuildRebuild Solution from the main menu.
  18. Check that the necessary schema has been created. This can be achieved using the mysql command interpreter.
    Figure 5.4 Membership and Role Provider Tables
    Membership and Role Provider Tables
  19. Assuming all is present and correct, you can now create users and roles for your web application. The easiest way to do this is with the ASP.NET Web Site Administration Tool. However, many web applications contain their own modules for creating roles and users. For simplicity, the ASP.NET Web Site Administration Tool will be used in this tutorial.
  20. In the ASP.NET Web Site Administration Tool, click the Security tab. Now that both the Membership and Role Provider are enabled, you will see links for creating roles and users. Click the Create or Manage Roles link.
    Figure 5.5 Security Tab
    Security Tab
  21. You can now enter the name of a new Role and click Add Role to create the new Role. Create new Roles as required.
  22. Click the Back button.
  23. Click the Create User link. You can now fill in information about the user to be created, and also allocate that user to one or more Roles.
    Figure 5.6 Create User
    Create User
  24. Using the mysql command interpreter, you can check that your database has been correctly populated with the Membership and Role data.
    Figure 5.7 Membership and Roles Table Contents
    Membership and Roles Table Contents
In this tutorial, you have seen how to set up the MySQL Connector/Net Membership and Role Providers for use in your ASP.NET web application.

No comments:

Post a Comment

Angular Tutorial (Update to Angular 7)

As Angular 7 has just been released a few days ago. This tutorial is updated to show you how to create an Angular 7 project and the new fe...