Merge branch 'dev_add_auth_1029' of http://192.168.5.200:8081/ql/apismnagaer_backend into dev_add_auth_1029
This commit is contained in:
commit
44c82129a4
@ -13,6 +13,7 @@
|
|||||||
<PrivateAssets>all</PrivateAssets>
|
<PrivateAssets>all</PrivateAssets>
|
||||||
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
|
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
|
||||||
</PackageReference>
|
</PackageReference>
|
||||||
|
<PackageReference Include="Newtonsoft.Json" Version="13.0.3" />
|
||||||
<PackageReference Include="Pomelo.EntityFrameworkCore.MySql" Version="8.0.0" />
|
<PackageReference Include="Pomelo.EntityFrameworkCore.MySql" Version="8.0.0" />
|
||||||
<PackageReference Include="Serilog" Version="4.1.0" />
|
<PackageReference Include="Serilog" Version="4.1.0" />
|
||||||
<PackageReference Include="Serilog.Extensions.Hosting" Version="8.0.0" />
|
<PackageReference Include="Serilog.Extensions.Hosting" Version="8.0.0" />
|
||||||
|
|||||||
@ -1,6 +1,8 @@
|
|||||||
using Apimanager_backend.Services;
|
using Apimanager_backend.Dtos;
|
||||||
|
using Apimanager_backend.Services;
|
||||||
using Microsoft.AspNetCore.Authentication.JwtBearer;
|
using Microsoft.AspNetCore.Authentication.JwtBearer;
|
||||||
using Microsoft.IdentityModel.Tokens;
|
using Microsoft.IdentityModel.Tokens;
|
||||||
|
using Newtonsoft.Json;
|
||||||
using StackExchange.Redis;
|
using StackExchange.Redis;
|
||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using System.Runtime.CompilerServices;
|
using System.Runtime.CompilerServices;
|
||||||
@ -29,6 +31,7 @@ namespace Apimanager_backend.Config
|
|||||||
services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme)
|
services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme)
|
||||||
.AddJwtBearer(options =>
|
.AddJwtBearer(options =>
|
||||||
{
|
{
|
||||||
|
//jwt参数
|
||||||
options.TokenValidationParameters = new TokenValidationParameters
|
options.TokenValidationParameters = new TokenValidationParameters
|
||||||
{
|
{
|
||||||
ValidateIssuer = true,
|
ValidateIssuer = true,
|
||||||
@ -39,11 +42,45 @@ namespace Apimanager_backend.Config
|
|||||||
ValidAudience = jwtSettings["Audience"],
|
ValidAudience = jwtSettings["Audience"],
|
||||||
IssuerSigningKey = new SymmetricSecurityKey(key)
|
IssuerSigningKey = new SymmetricSecurityKey(key)
|
||||||
};
|
};
|
||||||
|
//添加自定义响应处理函数
|
||||||
|
options.Events = new JwtBearerEvents
|
||||||
|
{
|
||||||
|
OnChallenge = new Func<JwtBearerChallengeContext, Task>(JwtTokenErrorEventFunc),
|
||||||
|
OnForbidden = new Func<ForbiddenContext, Task>(JwtPermissionEventFunc)
|
||||||
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
//redis配置
|
//redis配置
|
||||||
services.AddSingleton<IConnectionMultiplexer>(ConnectionMultiplexer.Connect(configuration["Redis:ConnectionString"]));
|
services.AddSingleton<IConnectionMultiplexer>(ConnectionMultiplexer.Connect(configuration["Redis:ConnectionString"]));
|
||||||
return services;
|
return services;
|
||||||
}
|
}
|
||||||
|
/// <summary>
|
||||||
|
/// token无效事件处理函数
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="context"></param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public async static Task JwtTokenErrorEventFunc(JwtBearerChallengeContext context)
|
||||||
|
{
|
||||||
|
context.Response.ContentType = "application/json";
|
||||||
|
var res = new ResponseBase<object?>(
|
||||||
|
code: 1002,
|
||||||
|
message: "用户未登录或认证失败",
|
||||||
|
data: null
|
||||||
|
);
|
||||||
|
context.Response.StatusCode = StatusCodes.Status401Unauthorized;
|
||||||
|
await context.Response.WriteAsync(JsonConvert.SerializeObject(res));
|
||||||
|
context.HandleResponse();
|
||||||
|
}
|
||||||
|
public async static Task JwtPermissionEventFunc(ForbiddenContext context)
|
||||||
|
{
|
||||||
|
context.Response.ContentType = "application/json";
|
||||||
|
var res = new ResponseBase<object?>(
|
||||||
|
code: 2006,
|
||||||
|
message: "用户无权限进行该操作",
|
||||||
|
data: null
|
||||||
|
);
|
||||||
|
context.Response.StatusCode = StatusCodes.Status401Unauthorized;
|
||||||
|
await context.Response.WriteAsync(JsonConvert.SerializeObject(res));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -100,31 +100,31 @@ namespace Apimanager_backend.Controllers
|
|||||||
if (isUsernameExist)
|
if (isUsernameExist)
|
||||||
{
|
{
|
||||||
var errorRes = new ResponseBase<UserInfoDto?>(
|
var errorRes = new ResponseBase<UserInfoDto?>(
|
||||||
code:2003,
|
code: 2003,
|
||||||
message:"用户名已存在",
|
message: "用户名已存在",
|
||||||
data:null
|
data: null
|
||||||
);
|
);
|
||||||
return StatusCode(409,errorRes);
|
return StatusCode(409, errorRes);
|
||||||
}
|
}
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var userInfo = await authService.RegisterAsync(requestDto);
|
var userInfo = await authService.RegisterAsync(requestDto);
|
||||||
var res = new ResponseBase<UserInfoDto?>(
|
var res = new ResponseBase<UserInfoDto?>(
|
||||||
code:1000,
|
code: 1000,
|
||||||
message:"Success",
|
message: "Success",
|
||||||
data:userInfo
|
data: userInfo
|
||||||
);
|
);
|
||||||
return Ok(res);
|
return Ok(res);
|
||||||
}catch(BaseException e)
|
}
|
||||||
|
catch (BaseException e)
|
||||||
{
|
{
|
||||||
var res = new ResponseBase<UserInfoDto?>(
|
var res = new ResponseBase<UserInfoDto?>(
|
||||||
code:e.code,
|
code: e.code,
|
||||||
message:e.message,
|
message: e.message,
|
||||||
data: null
|
data: null
|
||||||
);
|
);
|
||||||
return StatusCode(500,res);
|
return StatusCode(500, res);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 发送邮箱校验码
|
/// 发送邮箱校验码
|
||||||
|
|||||||
@ -4,6 +4,9 @@ using Apimanager_backend.Services;
|
|||||||
using Microsoft.AspNetCore.Http;
|
using Microsoft.AspNetCore.Http;
|
||||||
using Microsoft.AspNetCore.Mvc;
|
using Microsoft.AspNetCore.Mvc;
|
||||||
using Apimanager_backend.Filters;
|
using Apimanager_backend.Filters;
|
||||||
|
using Microsoft.AspNetCore.Authorization;
|
||||||
|
using Apimanager_backend.Models;
|
||||||
|
using System.Security.Claims;
|
||||||
|
|
||||||
namespace Apimanager_backend.Controllers
|
namespace Apimanager_backend.Controllers
|
||||||
{
|
{
|
||||||
@ -16,6 +19,18 @@ namespace Apimanager_backend.Controllers
|
|||||||
{
|
{
|
||||||
this.userService = userService;
|
this.userService = userService;
|
||||||
}
|
}
|
||||||
|
[HttpGet]
|
||||||
|
[Authorize(Roles = "User")]
|
||||||
|
public async Task<ActionResult<ResponseBase<UserInfoDto>>> UserInfo()
|
||||||
|
{
|
||||||
|
var userId = User.Claims.First(x => x.Type == "userId").Value;
|
||||||
|
var userInfo = await userService.GetUserAsync(int.Parse(userId));
|
||||||
|
var res = new ResponseBase<UserInfoDto>(
|
||||||
|
code:1000,
|
||||||
|
message:"Success",
|
||||||
|
data:userInfo
|
||||||
|
);
|
||||||
|
return Ok(res);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,6 +1,10 @@
|
|||||||
namespace Apimanager_backend.Dtos
|
using System.ComponentModel.DataAnnotations;
|
||||||
|
|
||||||
|
namespace Apimanager_backend.Dtos
|
||||||
{
|
{
|
||||||
public class UpdateUserDto
|
public class UpdateUserDto
|
||||||
{
|
{
|
||||||
|
public int? userId { get; set; }
|
||||||
|
public string? password { get; set; }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
40
Apimanager_backend/Services/IAdminService.cs
Normal file
40
Apimanager_backend/Services/IAdminService.cs
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
using Apimanager_backend.Dtos;
|
||||||
|
|
||||||
|
namespace Apimanager_backend.Services
|
||||||
|
{
|
||||||
|
public interface IAdminService
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// 禁用用户,使其无法登录。
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="userId">要禁用的用户ID</param>
|
||||||
|
/// <returns>异步操作</returns>
|
||||||
|
Task BanUserAsync(int userId);
|
||||||
|
/// <summary>
|
||||||
|
/// 取消禁用用户,恢复登录权限。
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="userId">要取消禁用的用户ID</param>
|
||||||
|
/// <returns>异步操作</returns>
|
||||||
|
Task UnbanUserAsync(int userId);
|
||||||
|
/// <summary>
|
||||||
|
/// 获取分页的用户列表。
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="page">要获取的页码,从1开始</param>
|
||||||
|
/// <param name="pageSize">每页的用户数量</param>
|
||||||
|
/// <param name="desc">是否按降序排序</param>
|
||||||
|
/// <returns>包含用户信息的 <see cref="List{UserInfoDto}"/></returns>
|
||||||
|
Task<List<UserInfoDto>> GetUsersAsync(int page, int pageSize, bool desc);
|
||||||
|
/// <summary>
|
||||||
|
/// 创建新用户。
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="user">包含新用户信息的 <see cref="CreateUserDto"/></param>
|
||||||
|
/// <returns>创建成功的用户信息 <see cref="UserInfoDto"/></returns>
|
||||||
|
Task<UserInfoDto> CreateUserAsync(CreateUserDto user);
|
||||||
|
/// <summary>
|
||||||
|
/// 删除指定的用户。
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="userId">用户ID</param>
|
||||||
|
/// <returns>异步操作</returns>
|
||||||
|
Task DeleteUserAsync(int userId);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -35,43 +35,6 @@ namespace Apimanager_backend.Services
|
|||||||
/// <param name="user">包含更新信息的 <see cref="UpdateUserDto"/></param>
|
/// <param name="user">包含更新信息的 <see cref="UpdateUserDto"/></param>
|
||||||
/// <returns>更新后的 <see cref="UserInfoDto"/></returns>
|
/// <returns>更新后的 <see cref="UserInfoDto"/></returns>
|
||||||
Task<UserInfoDto> UpdateUserAsync(UpdateUserDto user);
|
Task<UserInfoDto> UpdateUserAsync(UpdateUserDto user);
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 删除指定的用户。
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="username">要删除的用户名</param>
|
|
||||||
/// <returns>异步操作</returns>
|
|
||||||
Task DeleteUserAsync(string username);
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 创建新用户。
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="user">包含新用户信息的 <see cref="CreateUserDto"/></param>
|
|
||||||
/// <returns>创建成功的用户信息 <see cref="UserInfoDto"/></returns>
|
|
||||||
Task<UserInfoDto> CreateUserAsync(CreateUserDto user);
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 禁用用户,使其无法登录。
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="username">要禁用的用户名</param>
|
|
||||||
/// <returns>异步操作</returns>
|
|
||||||
Task BanUserAsync(string username);
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 取消禁用用户,恢复登录权限。
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="username">要取消禁用的用户名</param>
|
|
||||||
/// <returns>异步操作</returns>
|
|
||||||
Task UnbanUserAsync(string username);
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 获取分页的用户列表。
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="page">要获取的页码,从1开始</param>
|
|
||||||
/// <param name="pageSize">每页的用户数量</param>
|
|
||||||
/// <param name="desc">是否按降序排序</param>
|
|
||||||
/// <returns>包含用户信息的 <see cref="List{UserInfoDto}"/></returns>
|
|
||||||
Task<List<UserInfoDto>> GetUsersAsync(int page, int pageSize, bool desc);
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 检测用户名是否被使用
|
/// 检测用户名是否被使用
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@ -19,21 +19,6 @@ namespace Apimanager_backend.Services
|
|||||||
this.apiContext = apiContext;
|
this.apiContext = apiContext;
|
||||||
this.mapper = automapper;
|
this.mapper = automapper;
|
||||||
}
|
}
|
||||||
public Task BanUserAsync(string username)
|
|
||||||
{
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Task<UserInfoDto> CreateUserAsync(CreateUserDto user)
|
|
||||||
{
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Task DeleteUserAsync(string username)
|
|
||||||
{
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public async Task<UserInfoDto> GetUserAsync(int userId)
|
public async Task<UserInfoDto> GetUserAsync(int userId)
|
||||||
{
|
{
|
||||||
User? user = await apiContext.Users.SingleOrDefaultAsync(x => x.Id == userId);
|
User? user = await apiContext.Users.SingleOrDefaultAsync(x => x.Id == userId);
|
||||||
@ -45,11 +30,6 @@ namespace Apimanager_backend.Services
|
|||||||
return mapper.Map<UserInfoDto>(user);
|
return mapper.Map<UserInfoDto>(user);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Task<List<UserInfoDto>> GetUsersAsync(int page, int pageSize, bool desc)
|
|
||||||
{
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public async Task<bool> IsEmailExist(string email)
|
public async Task<bool> IsEmailExist(string email)
|
||||||
{
|
{
|
||||||
return await apiContext.Users.AnyAsync(x => x.Email == email);
|
return await apiContext.Users.AnyAsync(x => x.Email == email);
|
||||||
@ -70,14 +50,19 @@ namespace Apimanager_backend.Services
|
|||||||
throw new NotImplementedException();
|
throw new NotImplementedException();
|
||||||
}
|
}
|
||||||
|
|
||||||
public Task UnbanUserAsync(string username)
|
|
||||||
{
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Task<UserInfoDto> UpdateUserAsync(UpdateUserDto user)
|
public async Task<UserInfoDto> UpdateUserAsync(UpdateUserDto dto)
|
||||||
{
|
{
|
||||||
throw new NotImplementedException();
|
var user = await apiContext.Users.FirstOrDefaultAsync(x => x.Id == dto.userId);
|
||||||
|
if (user == null)
|
||||||
|
{
|
||||||
|
throw new BaseException(2004, "用户不存在");
|
||||||
|
}
|
||||||
|
user.PassHash = dto.password == null ? user.PassHash : dto.password;
|
||||||
|
|
||||||
|
apiContext.Users.Update(user);
|
||||||
|
await apiContext.SaveChangesAsync();
|
||||||
|
return mapper.Map<UserInfoDto>(user);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user