😎增加移动端接口特性及实现
This commit is contained in:
parent
1a10d0a365
commit
b0bfe08ac8
@ -35,7 +35,7 @@
|
|||||||
<PackageReference Include="Novell.Directory.Ldap.NETStandard" Version="3.6.0" />
|
<PackageReference Include="Novell.Directory.Ldap.NETStandard" Version="3.6.0" />
|
||||||
<PackageReference Include="QRCoder" Version="1.6.0" />
|
<PackageReference Include="QRCoder" Version="1.6.0" />
|
||||||
<PackageReference Include="RabbitMQ.Client" Version="6.8.1" />
|
<PackageReference Include="RabbitMQ.Client" Version="6.8.1" />
|
||||||
<PackageReference Include="SixLabors.ImageSharp.Web" Version="3.1.3" />
|
<PackageReference Include="SixLabors.ImageSharp.Web" Version="3.1.2" />
|
||||||
<PackageReference Include="SkiaSharp.NativeAssets.Linux.NoDependencies" Version="2.88.8" />
|
<PackageReference Include="SkiaSharp.NativeAssets.Linux.NoDependencies" Version="2.88.8" />
|
||||||
<PackageReference Include="SKIT.FlurlHttpClient.Wechat.Api" Version="3.5.0" />
|
<PackageReference Include="SKIT.FlurlHttpClient.Wechat.Api" Version="3.5.0" />
|
||||||
<PackageReference Include="SKIT.FlurlHttpClient.Wechat.TenpayV3" Version="3.8.0" />
|
<PackageReference Include="SKIT.FlurlHttpClient.Wechat.TenpayV3" Version="3.8.0" />
|
||||||
|
|||||||
@ -0,0 +1,22 @@
|
|||||||
|
// Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
|
||||||
|
//
|
||||||
|
// 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
|
||||||
|
//
|
||||||
|
// 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
|
||||||
|
|
||||||
|
namespace Admin.NET.Core;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// APP接口特性
|
||||||
|
/// </summary>
|
||||||
|
[SuppressSniffer]
|
||||||
|
[AttributeUsage(AttributeTargets.Class, AllowMultiple = true, Inherited = true)]
|
||||||
|
public class AppApiDescriptionAttribute : Attribute
|
||||||
|
{
|
||||||
|
public string Name { get; set; }
|
||||||
|
|
||||||
|
public AppApiDescriptionAttribute(string name)
|
||||||
|
{
|
||||||
|
Name = name;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -16,6 +16,11 @@ public class CacheConst
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public const string KeyUserApi = "sys_user_api:";
|
public const string KeyUserApi = "sys_user_api:";
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 移动端接口缓存(接口集合)
|
||||||
|
/// </summary>
|
||||||
|
public const string KeyAppApi = "sys_app_api:";
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 用户机构缓存
|
/// 用户机构缓存
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@ -63,9 +63,10 @@ public class SysCommonService : IDynamicApiController, ITransient
|
|||||||
/// 获取所有接口/动态API 🔖
|
/// 获取所有接口/动态API 🔖
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="groupName"></param>
|
/// <param name="groupName"></param>
|
||||||
|
/// <param name="isAppApi"></param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
[DisplayName("获取所有接口/动态API")]
|
[DisplayName("获取所有接口/动态API")]
|
||||||
public List<ApiOutput> GetApiList([FromQuery] string groupName = "")
|
public List<ApiOutput> GetApiList([FromQuery] string groupName = "", [FromQuery] bool isAppApi = false)
|
||||||
{
|
{
|
||||||
var apiList = new List<ApiOutput>();
|
var apiList = new List<ApiOutput>();
|
||||||
|
|
||||||
@ -99,6 +100,14 @@ public class SysCommonService : IDynamicApiController, ITransient
|
|||||||
var controllerActionDescriptor = action.ActionDescriptor as ControllerActionDescriptor;
|
var controllerActionDescriptor = action.ActionDescriptor as ControllerActionDescriptor;
|
||||||
if (controllerActionDescriptor == null)
|
if (controllerActionDescriptor == null)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
// 是否只获取所有的移动端/AppApi接口
|
||||||
|
if (isAppApi)
|
||||||
|
{
|
||||||
|
var appApiDescription = controllerActionDescriptor.ControllerTypeInfo.GetCustomAttribute<AppApiDescriptionAttribute>(true);
|
||||||
|
if (appApiDescription == null) continue;
|
||||||
|
}
|
||||||
|
|
||||||
var apiDescription = controllerActionDescriptor.ControllerTypeInfo.GetCustomAttribute<ApiDescriptionSettingsAttribute>(true);
|
var apiDescription = controllerActionDescriptor.ControllerTypeInfo.GetCustomAttribute<ApiDescriptionSettingsAttribute>(true);
|
||||||
var controllerName = controllerActionDescriptor.ControllerName;
|
var controllerName = controllerActionDescriptor.ControllerName;
|
||||||
var controllerText = apiDescription?.Description;
|
var controllerText = apiDescription?.Description;
|
||||||
@ -137,6 +146,30 @@ public class SysCommonService : IDynamicApiController, ITransient
|
|||||||
return apiList;
|
return apiList;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 获取所有移动端接口
|
||||||
|
/// </summary>
|
||||||
|
/// <returns></returns>
|
||||||
|
[DisplayName("获取所有移动端接口")]
|
||||||
|
public List<string> GetAppApiList()
|
||||||
|
{
|
||||||
|
var sysCacheService = App.GetRequiredService<SysCacheService>();
|
||||||
|
var apiList = sysCacheService.Get<List<string>>(CacheConst.KeyAppApi);
|
||||||
|
if (apiList == null)
|
||||||
|
{
|
||||||
|
apiList = new List<string>();
|
||||||
|
|
||||||
|
var allApiList = GetApiList("", true);
|
||||||
|
foreach (var apiOutput in allApiList)
|
||||||
|
{
|
||||||
|
foreach (var controller in apiOutput.Children)
|
||||||
|
apiList.AddRange(controller.Children.Select(u => u.Route));
|
||||||
|
}
|
||||||
|
sysCacheService.Set(CacheConst.KeyAppApi, apiList, TimeSpan.FromDays(7));
|
||||||
|
}
|
||||||
|
return apiList;
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 下载标记错误的临时 Excel(全局) 🔖
|
/// 下载标记错误的临时 Excel(全局) 🔖
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@ -81,13 +81,20 @@ namespace Admin.NET.Web.Core
|
|||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
private static async Task<bool> CheckAuthorizeAsync(DefaultHttpContext httpContext)
|
private static async Task<bool> CheckAuthorizeAsync(DefaultHttpContext httpContext)
|
||||||
{
|
{
|
||||||
// 排除超管账号
|
// 排除超管权限判断
|
||||||
if (App.User.FindFirst(ClaimConst.AccountType)?.Value == ((int)AccountTypeEnum.SuperAdmin).ToString())
|
if (App.User.FindFirst(ClaimConst.AccountType)?.Value == ((int)AccountTypeEnum.SuperAdmin).ToString())
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
// 当前接口路由
|
// 当前接口路由
|
||||||
var path = httpContext.Request.Path.ToString();
|
var path = httpContext.Request.Path.ToString();
|
||||||
|
|
||||||
|
// 移动端接口权限判断
|
||||||
|
if (App.User.FindFirst(ClaimConst.LoginMode)?.Value == ((int)LoginModeEnum.APP).ToString())
|
||||||
|
{
|
||||||
|
var appApiList = App.GetRequiredService<SysCommonService>().GetAppApiList(); // 获取移动端所有接口
|
||||||
|
return appApiList.Exists(u => path.EndsWith(u, StringComparison.CurrentCultureIgnoreCase));
|
||||||
|
}
|
||||||
|
|
||||||
// 获取当前用户按钮权限集合和接口黑名单
|
// 获取当前用户按钮权限集合和接口黑名单
|
||||||
var serviceScope = httpContext.RequestServices.CreateScope();
|
var serviceScope = httpContext.RequestServices.CreateScope();
|
||||||
var sysRoleService = serviceScope.ServiceProvider.GetRequiredService<SysRoleService>();
|
var sysRoleService = serviceScope.ServiceProvider.GetRequiredService<SysRoleService>();
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user