最近有个web项目需求就是在部署完成启动时,需要完成自动创建默认账户角色、用户以及密码的功能
工具
- visualStudio 2022
- Sqlserver 2014
版本
.net 6
思路
- 创建一个静态类用于实现初始化的功能
- 在program.cs 中调用静态类实现
- 注意:这里初始化信息分别为(role----->admin user----->admin password----->admin),设置用户admin到role中的admin下。
代码参考
1、DbInitializer静态类
public static class DbInitializer
{
public static async Task Initialize(MyDbContext myDbcontext, UserManager<MyUser> userManager, RoleManager<MyRole> roleManager)
{
//查询admin的角色是否存在
bool roleExist = await roleManager.RoleExistsAsync("admin");
//如果没存在就创建
if (!roleExist)
{
MyRole role = new MyRole {
Name = "admin" };
//创建role
var r = await roleManager.CreateAsync(role);
}
//创建user
MyUser myUser = await userManager.FindByNameAsync("admin");
//如果没有用户
if (myUser == null)
{
MyUser user = new MyUser {
UserName = "admin" };
var u = await userManager.CreateAsync(user, "admin");
//将用户添加到role中
var r = await userManager.AddToRoleAsync(user, "admin");
}
}
这里没有做异常处理,仅作思路展示,切勿直接用于生产
2、在program.cs中调用静态类
var app = builder.Build();
//初始化默认账户
AsyncServiceScope sc = app.Services.CreateAsyncScope();
var sp = sc.ServiceProvider;
MyDbContext mD = sp.GetService<MyDbContext>();
UserManager<MyUser> mU = sp.GetService<UserManager<MyUser>>();
RoleManager<MyRole> mR = sp.GetService<RoleManager<MyRole>>();
DbInitializer.Initialize(mD, mU, mR);