ASP.NET MVC 4 SimpleMembership Provider (1)

新的ASP.NET MVC 4.0 提供了一个新的Membership Provider,叫SimpleMembership.html

首先,咱们创建一个新的solutionweb

 

首先咱们先看一下web.config数据库

  1. <connectionStrings>
  2.     <add name="DefaultConnection" connectionString="Data Source=(LocalDb)\v11.0;Initial Catalog=aspnet-MVC4SimpleMembershipSample-20130911133958;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|\aspnet-MVC4SimpleMembershipSample-20130911133958.mdf" providerName="System.Data.SqlClient" />
  3.  </connectionStrings>

 

在这里咱们要注意一下,咱们连接的是visual studio 2012自带的LocalDb,如需链接,请用(LocalDb)\v11.0做为Server的名字ide

打开Web.config文件,加入一下内容测试

  1. <roleManager enabled="true" defaultProvider="SimpleRoleProvider">
  2.       <providers>
  3.         <clear/>
  4.         <add name="SimpleRoleProvider" type="WebMatrix.WebData.SimpleRoleProvider, WebMatrix.WebData"/>
  5.       </providers>
  6. </roleManager>
  7. <membership defaultProvider="SimpleMembershipProvider">
  8.       <providers>
  9.         <clear/>
  10.         <add name="SimpleMembershipProvider" type="WebMatrix.WebData.SimpleMembershipProvider, WebMatrix.WebData" />
  11.       </providers>
  12. </membership>

 

打开AccountController.cs, 找到UserProfile 这个class网站

好比咱们加入一个自定义的属性叫Address,spa

由于咱们使用的是code first, 这时候,咱们要enable-migrationscode

完成后htm

打开Migrations\Configuration.cs以后 你能够看到自动生成的class的代码是这样的。blog

这时候,咱们要修改一下里面的内容

首先,咱们先引用

using WebMatrix.WebData;

using System.Web.Security;

修改下面的代码

  1. public Configuration()
  2.         {
  3.             AutomaticMigrationsEnabled = true;
  4.         }
  5.  
  6.         protected override void Seed(MVC4SimpleMembershipSample.Models.UsersContext context)
  7.         {
  8.             // This method will be called after migrating to the latest version.
  9.  
  10.             // You can use the DbSet<T>.AddOrUpdate() helper extension method
  11.             // to avoid creating duplicate seed data. E.g.
  12.             //
  13.             // context.People.AddOrUpdate(
  14.             // p => p.FullName,
  15.             // new Person { FullName = "Andrew Peters" },
  16.             // new Person { FullName = "Brice Lambson" },
  17.             // new Person { FullName = "Rowan Miller" }
  18.             // );
  19.             //
  20.  
  21.             WebSecurity.InitializeDatabaseConnection("DefaultConnection", "UserProfile", "UserId", "UserName", autoCreateTables: true);
  22.  
  23.             //create roles
  24.             if (!Roles.RoleExists("Admin"))
  25.                 Roles.CreateRole("Admin");
  26.  
  27.             //create a user called manager 1
  28.             if (!WebSecurity.UserExists("manager1"))
  29.                 WebSecurity.CreateUserAndAccount("manager1", "password", new { Address = "123 Evergreen Ave" });
  30.  
  31.             //assign manager1 to Admin role
  32.             if (!Roles.GetRolesForUser("manager1").Contains("Admin"))
  33.                 Roles.AddUserToRole("manager1", "Admin");
  34.         }

 

要注意一点!

这必定要改为true

 

而后再Package Manager Console下运行 update-database –verbose来修改数据库。

这时候咱们检视一下数据库的情况

能够看到,咱们以前在Code First中init的那个user和role已经在数据库中了。

这时候,咱们运行整个web程序,使用咱们以前已经定义好的user/password, manager1 和password

能够看到,咱们已经login到这个网站中去了。

好了,让咱们来测试一下Role的功能

当前角色是Admin的角色的话,咱们会在Index页面显示一个秘密的信息

 

 

打开Views\Home\Index.cshtml

咱们添加以下代码

成功!

相关文章
相关标签/搜索