سلام.
یک سایت طراحی کردم که در آن جدول Roles رو شخصی سازی کردم تا در قسمتی از سایت از آن استفاده کنم و در sql server جدول AspNetRoles که مربوط به آن است را به صورت دستی مقداردهی کردم اما نمیدانم چرا موقع اجرا مقدار null برای جدول نقش ها برگردانده میشود.
کدها:
شخصی سازی جدول نقش ها
public class ApplicationRole : IdentityRole
{
public string RoleLevel { get; set; }
public string Description { get; set; }
}
ایجاد تغییرات در ApplicationDbContext
public class ApplicationDbContext : IdentityDbContext
{
public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options)
: base(options)
{
}
public DbSet<ApplicationRole> ApplicationRoles { get; set; }
}
اکشن خواندن داده های جدول نقش ها:
public class IndexModel : PageModel
{
private readonly RoleManager<ApplicationRole> _roleManager;
public IndexModel(RoleManager<ApplicationRole> roleManager)
{
_roleManager = roleManager;
}
public ActionResult OnGet()
{
var list= _roleManager.Roles.ToList();
return Page();
}
}
با دستورات
Add-migration EditRoles
update-database
تغییرات را در دیتابیس ایجاد کردم.
یک breakpoint در خط 12 اکشن onGet (کد return Page) قرار دادم تا با فراخوانی اکشن onGet صفحه index اجرا در آن نقطه متوقف شود و بتوان مقدار متغیر list را بررسی کنم که مقدار آن برابر null است.
میخواستم ببینم مشکل کجاست که مقدار null را برای list بر میگرداند با این که من چندین رکورد را در جدول AspNetRoles ثبت کردم؟
فکر می کنم دستوراتتتون برای دریافت نقش ها مشکل داشته باشه. چون شما میخواید همه نقش های جدول رو بخونید بهتره از خود context استفاده کنید :
private readonly ApplicationDbContext _context;
public HomeController()
{
_context = context;
}
public IActionResult Index()
{
var roleList = _context.ApplicationRoles.ToList();
}
البته این نکته رو هم بگم شما در کلاس ApplicationDbContext از IdentityDbContext استفاده کردید. این کلاس خودش شامل 7 جدول Identity هست. بنابراین دیگه نیازی نیست دوباره یک DbSet به نام ApplicationRoles تعریف کنید.
سلام.اتفاقاً این رو من تست کردم اما بازم مقدار list برابر null بود.
private readonly ApplicationDbContext _db;
public IndexModel(ApplicationDbContext db)
{
_db = db;
}
public ActionResult OnGet()
{
var list= _db.Roles.ToList();
return Page();
}
البته با کد زیر می توان نقش ها را دریافت کرد اما فقط فیلدهای IdentityRole رو شامل می دهد و فیلد هایی که به وسیله کلاس ApplicationRole تعریف کردم شامل نمی شود
public class IndexModel : PageModel
{
private readonly RoleManager<IdentityRole> _roleManager;
public IndexModel(RoleManager<IdentityRole> roleManager)
{
_roleManager = roleManager;
}
public ActionResult OnGet()
{
var list= _roleManager.Roles.ToList();
return Page();
}
}
تاریخ :
1403/06/14
- ساعت :
06:44:00 PM
- بازدید :
148
- پاسخ :
0
|
تاریخ :
1398/11/07
- ساعت :
02:26:00 PM
- بازدید :
3554
- پاسخ :
5
|
تاریخ :
1403/06/17
- ساعت :
04:22:00 PM
- بازدید :
68
- پاسخ :
0
|
تاریخ :
1403/06/05
- ساعت :
05:47:00 PM
- بازدید :
145
- پاسخ :
2
|
تاریخ :
1403/06/06
- ساعت :
11:53:00 AM
- بازدید :
106
- پاسخ :
0
|
تاریخ :
1403/05/30
- ساعت :
09:22:00 AM
- بازدید :
122
- پاسخ :
1
|
تاریخ :
1403/05/31
- ساعت :
09:04:00 PM
- بازدید :
84
- پاسخ :
0
|
تاریخ :
1403/05/30
- ساعت :
01:35:00 PM
- بازدید :
94
- پاسخ :
1
|
تاریخ :
1398/09/14
- ساعت :
01:58:00 PM
- بازدید :
4001
- پاسخ :
1
|
تاریخ :
1403/05/20
- ساعت :
09:18:00 PM
- بازدید :
177
- پاسخ :
0
|
تاریخ :
1403/06/14
- ساعت :
06:44:00 PM
- بازدید :
148
- پاسخ :
0
|
تاریخ :
1398/11/07
- ساعت :
02:26:00 PM
- بازدید :
3554
- پاسخ :
5
|
تاریخ :
1403/06/17
- ساعت :
04:22:00 PM
- بازدید :
68
- پاسخ :
0
|
تاریخ :
1403/06/05
- ساعت :
05:47:00 PM
- بازدید :
145
- پاسخ :
2
|
تاریخ :
1403/06/06
- ساعت :
11:53:00 AM
- بازدید :
106
- پاسخ :
0
|
تاریخ :
1403/05/30
- ساعت :
09:22:00 AM
- بازدید :
122
- پاسخ :
1
|
تاریخ :
1403/05/31
- ساعت :
09:04:00 PM
- بازدید :
84
- پاسخ :
0
|
تاریخ :
1403/05/30
- ساعت :
01:35:00 PM
- بازدید :
94
- پاسخ :
1
|
تاریخ :
1398/09/14
- ساعت :
01:58:00 PM
- بازدید :
4001
- پاسخ :
1
|
تاریخ :
1398/09/16
- ساعت :
11:41:00 AM
- بازدید :
4017
- پاسخ :
1
|