当前位置: 首页 > news >正文

网站制作一般多少钱/东莞网络营销优化

网站制作一般多少钱,东莞网络营销优化,网站宣传怎样做不违法,福州设计公司排行文章目录 前言一、核心功能二、核心组件三、使用1)创建项目2)安装必要 NuGet包3)配置数据库连接字符串4)用户与角色实体定义4)配置数据库上下文5) 注册服务6)数据库迁移与初始化7)用…

文章目录

  • 前言
  • 一、核心功能
  • 二、核心组件
  • 三、使用
    • 1)创建项目
    • 2)安装必要 NuGet包
    • 3)配置数据库连接字符串
    • 4)用户与角色实体定义
    • 4)配置数据库上下文
    • 5) 注册服务
    • 6)数据库迁移与初始化
    • 7)用户管理功能实现
    • 8)认证与授权配置
  • 四、常见问题与调试
  • 总结


前言

ASP.NET Core Identity 是一个用于管理用户身份验证、授权和用户信息的框架,它是 ASP.NET Core 平台的重要组成部分。它为开发者提供了一套完整的工具和 API,用于处理用户注册、登录、密码管理、角色权限、第三方登录(如 Google、Facebook)等常见功能。

一、核心功能

  • 用户管理
    支持创建、更新、删除用户,管理用户信息(用户名、邮箱、密码等)。

  • 身份验证(Authentication)
    验证用户身份(如登录),支持 Cookie 认证、JWT(用于 API)、OAuth 2.0、OpenID Connect 等。

  • 授权(Authorization)
    基于角色(Role-Based)或策略(Policy-Based)控制资源访问权限。

  • 密码安全
    内置密码哈希、密码复杂度策略、账户锁定(防暴力破解)等功能。

  • 多因素认证(2FA)
    支持短信、邮件、验证器应用(如 Google Authenticator)等二次验证方式。

  • 外部登录集成
    快速集成第三方登录(如 Google、Facebook、Microsoft、GitHub 等)。

  • 用户声明(Claims)
    支持基于声明的授权模型,灵活定义用户属性。

  • 角色和权限管理
    创建角色并为用户分配角色,实现基于角色的访问控制。

二、核心组件

  • UserManager<TUser>
    管理用户(创建、删除、查找、修改密码等),泛型 TUser 通常是 IdentityUser 或其子类。

  • SignInManager<TUser>
    处理用户登录、登出、外部登录等操作。

  • RoleManager<TRole>
    管理角色(创建、删除、分配权限等),TRole 默认为 IdentityRole

  • IdentityUser 和 IdentityRole
    内置的用户和角色模型,可扩展自定义字段。

  • Entity Framework Core 集成
    默认使用 EF Core 存储用户和角色数据,支持 SQL Server、SQLite、PostgreSQL 等数据库。

三、使用

1)创建项目

  1. 使用 Visual Studio 创建 ASP.NET Core Web API 项目

2)安装必要 NuGet包

  1. 核心依赖包括 IdentityEF Core 的集成包:
    Install-Package Microsoft.AspNetCore.Identity.EntityFrameworkCore
    Install-Package Microsoft.EntityFrameworkCore.SqlServer
    Install-Package Microsoft.EntityFrameworkCore.Tools
    

3)配置数据库连接字符串

  1. appsettings.json 中添加数据库连接配置:
     "ConnectionStrings": {"DefaultConnection": "Server=XXX;Database=XXX;User Id=sa;Password=XXX;TrustServerCertificate=True;Trusted_Connection=True;MultipleActiveResultSets=True"}
    

4)用户与角色实体定义

  1. 自定义用户类
    继承 IdentityUser 并扩展属性(如创建时间):
    using Microsoft.AspNetCore.Identity;namespace IdentityProject.Entity
    {public class ApplicationUser:IdentityUser<long>{public DateTime CreateTime { get; set; }}
    }	
    
  2. 自定义角色类
    继承 IdentityRole(主键类型需与用户类一致):
    using Microsoft.AspNetCore.Identity;namespace IdentityProject.Entity
    {public class ApplicationRole:IdentityRole<long>{}
    }
    

4)配置数据库上下文

  1. 创建 DbContext
    继承 IdentityDbContext 并指定用户、角色类型:
    using IdentityProject.Entity;
    using Microsoft.AspNetCore.Identity.EntityFrameworkCore;
    using Microsoft.EntityFrameworkCore;namespace IdentityProject.Data
    {public class MyDbContext : IdentityDbContext<ApplicationUser,ApplicationRole,long>{public MyDbContext(DbContextOptions<MyDbContext> options) : base(options){}}
    }
    
  2. 创建MyDbContextDesignTimeFactory.cs
    using Microsoft.EntityFrameworkCore;
    using Microsoft.EntityFrameworkCore.Design;namespace IdentityProject.Data
    {public class MyDbContextDesignTimeFactory : IDesignTimeDbContextFactory<MyDbContext>{public MyDbContext CreateDbContext(string[] args){DbContextOptionsBuilder<MyDbContext> builder=  new DbContextOptionsBuilder<MyDbContext>();builder.UseSqlServer("Server=XXX;Database=XXX;User Id=sa;Password=XXX;TrustServerCertificate=True;Trusted_Connection=True;MultipleActiveResultSets=True");return new MyDbContext(builder.Options);}}
    }
    

5) 注册服务

  1. Program.cs 中配置 Identity数据库服务
    var connectionString = builder.Configuration.GetConnectionString("DefaultConnection");builder.Services.AddDbContext<MyDbContext>(opt => {opt.UseSqlServer(connectionString);});builder.Services.AddIdentityCore<ApplicationUser>(opt => {opt.Lockout.MaxFailedAccessAttempts = 5;//登录失败多少次账号被锁定opt.Lockout.DefaultLockoutTimeSpan = TimeSpan.FromMinutes(1);//锁定多长时间opt.Password.RequireDigit = false;//密码是否需要数字    opt.Password.RequireLowercase = false;//密码是否需要小写字符opt.Password.RequireUppercase = false;//密码是否需要大写字符opt.Password.RequireNonAlphanumeric = false;//密码是否需要非字母数字的字符opt.Password.RequiredLength = 6;//密码长度opt.Tokens.PasswordResetTokenProvider = TokenOptions.DefaultEmailProvider;//密码重置令牌,使用默认的邮箱令牌提供程序来生成和验证令牌。此提供程序通常与用户邮箱关联,生成的令牌会通过邮件发送给用户,保证用户通过邮件接收密码重置链接。opt.Tokens.EmailConfirmationTokenProvider = TokenOptions.DefaultEmailProvider;//配置邮箱确认令牌(Email Confirmation Token)的生成和验证所使用的提供程序(Provider)var idBuilder = new IdentityBuilder(typeof(ApplicationUser), typeof(ApplicationRole), builder.Services);idBuilder.AddEntityFrameworkStores<MyDbContext>().AddDefaultTokenProviders().AddUserManager<UserManager<ApplicationUser>>().AddRoleManager<RoleManager<ApplicationRole>>();
    

6)数据库迁移与初始化

  1. 生成迁移文件
    执行 EF Core 命令创建迁移:

    Add-Migration Init
    
  2. 更新数据库
    应用迁移以生成 Identity 相关表:

    Update-Database
    

7)用户管理功能实现

  1. 创建角色、用户注册、角色分配、用户登录
    使用 UserManager 创建用户:
    using IdentityProject.Entity;
    using Microsoft.AspNetCore.Identity;
    using Microsoft.AspNetCore.Mvc;namespace IdentityProject.Controllers
    {[Route("api/[controller]/[action]")][ApiController]public class TestController : ControllerBase{private readonly UserManager<ApplicationUser> _userManager;private readonly RoleManager<ApplicationRole> _roleManager;private readonly IWebHostEnvironment _webHostEnvironment;public TestController(UserManager<ApplicationUser> userManager, RoleManager<ApplicationRole> roleManager, IWebHostEnvironment webHostEnvironment){_userManager = userManager;_roleManager = roleManager;_webHostEnvironment = webHostEnvironment;}[HttpPost]public async Task<ActionResult<string>> Test(){if (!await _roleManager.RoleExistsAsync("admin")){ApplicationRole role=new ApplicationRole { Name = "admin" };//创建角色var res=await _roleManager.CreateAsync(role);if (!res.Succeeded) return BadRequest("CreateRoleAsync Failed");}ApplicationUser user=await _userManager.FindByNameAsync("LGF");if (user == null){user = new ApplicationUser { UserName="LGF"};//创建用户var res=await _userManager.CreateAsync(user, "123456");if (!res.Succeeded){return BadRequest("CreateUserAsync Failed");}}var inRole=await _userManager.IsInRoleAsync(user, "admin");if (!inRole){//分配角色var res=await _userManager.AddToRoleAsync(user, "admin");if (!res.Succeeded) return BadRequest("UserManager AddToRoleAsync Failed");}return "Success";}/// <summary>/// 登录/// </summary>/// <param name="request"></param>/// <returns></returns>[HttpPost]public async Task<ActionResult> Login(CheckPwdRequest request){string userName=request.UserName;string password=request.Password;var user = await _userManager.FindByNameAsync(userName);if (user == null){if (_webHostEnvironment.IsDevelopment()){return BadRequest("用户不存在");}return BadRequest();}bool locked = await _userManager.IsLockedOutAsync(user);if (locked){return BadRequest($"用户被锁定,锁定结束时间为:{user.LockoutEnd}");}bool validatePwd = await _userManager.CheckPasswordAsync(user, password);if (validatePwd){await _userManager.ResetAccessFailedCountAsync(user);return Ok("登录成功");}else{await _userManager.AccessFailedAsync(user);return BadRequest($"{userName} Login Failed ,Password is wrong");}}}
    }
    

8)认证与授权配置

  1. 启用中间件
    在请求管道中添加认证与授权中间件(顺序不可颠倒):
    app.UseAuthentication();
    app.UseAuthorization();
    
  2. 控制器授权
    使用 [Authorize] 属性限制访问:
    [Authorize(Roles = "admin")]
    [ApiController]
    public class AdminController : ControllerBase { }
    
  3. 策略授权
    自定义策略(如年龄限制):
    services.AddAuthorization(options =>
    {options.AddPolicy("AdultOnly", policy => policy.RequireClaim("Age", "18"));
    });
    

四、常见问题与调试

  • 迁移错误:检查 DbContext 是否继承自 IdentityDbContext,确保连接字符串正确。

  • 中间件顺序UseAuthentication 必须在 UseAuthorization 之前。

  • 密码策略冲突:通过 IdentityOptions 调整复杂度要求。


总结

基于 ASP.NET Core IdentityWeb API 身份系统,支持用户管理、角色授权及扩展功能。

http://www.whsansanxincailiao.cn/news/30723294.html

相关文章:

  • 网站建设这一行业怎样/如何在手机上制作网站
  • 成都网站的/自动点击器怎么用
  • 网站换模板/小白如何学电商运营
  • 网站图片轮播怎么做/企业网站类型有哪些
  • 自动生成ui界面/亚马逊排名seo
  • 旅游网站 div css 模板下载/公关公司经营范围
  • 淄博网站排名优化公司/营销软文的范文
  • 下班后做兼职任务网站/新闻发稿推广
  • 上海做网站吧/天津关键词优化专家
  • 建一个商城网站需要多少钱/智慧教育
  • 虾皮购物网站怎么做/优化方案的格式及范文
  • wordpress 提供了 支持/西安搜索引擎优化
  • 网站留言板有什么用/网站查询服务器
  • 做网站制作利润有多少/海南百度推广公司
  • 无锡做网站哪家公司好/网络推广是什么工作内容
  • 泰州网站建设物美价廉/广东公司搜索seo哪家强
  • 做的好的阅读类的网站有哪些/上海网络seo公司
  • 互联网网站建设制作/优化营商环境 提升服务效能
  • 微信公众号链接网站怎么做/百度竞价推广账户优化
  • 百度做网站的特点/友链网站
  • 医疗网站做药品是干嘛/seo网站营销推广
  • 网页升级紧急通知合集/网站优化员seo招聘
  • 网站模板与网站开发/石家庄最新消息
  • 广告公司资质/seo优化课程
  • 视频直播nba的网站/网站推广 方法
  • 株洲百度推广/seo顾问服务四川
  • 东莞著名网站建设企业/营销管理培训课程
  • html5 网站框架/病毒式营销
  • 怎么做网站导航条/seo搜索引擎优化入门
  • 推动高质量发展建议/长沙网站seo公司