From 5e4cdbe7f0d474d0d31d453e2ce1e70552e4a274 Mon Sep 17 00:00:00 2001 From: JianWeie Date: Tue, 27 Jul 2021 01:23:06 +0800 Subject: [PATCH] =?UTF-8?q?=E3=80=90=E5=90=8E=E7=AB=AF=E3=80=91=E4=BC=98?= =?UTF-8?q?=E5=8C=96=E5=90=8E=E7=AB=AF=E8=AE=BE=E7=BD=AE=E6=9D=83=E9=99=90?= =?UTF-8?q?=E8=A7=92=E8=89=B2=EF=BC=8C=E5=8F=8D=E5=B0=84controller?= =?UTF-8?q?=E5=92=8Caction=E7=9A=84=E6=95=88=E7=8E=87=E9=97=AE=E9=A2=98?= =?UTF-8?q?=E3=80=82?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../AdminsControllerPermission.cs | 53 +++++++++++-------- 1 file changed, 32 insertions(+), 21 deletions(-) diff --git a/CoreCms.Net.Filter/AdminsControllerPermission.cs b/CoreCms.Net.Filter/AdminsControllerPermission.cs index fca13b6..c22458d 100644 --- a/CoreCms.Net.Filter/AdminsControllerPermission.cs +++ b/CoreCms.Net.Filter/AdminsControllerPermission.cs @@ -31,9 +31,13 @@ namespace CoreCms.Net.Filter var types = Assembly.Load("CoreCms.Net.Web.Admin").GetTypes(); - foreach (var type in types) + + var noController = new[] { "ToolsController", "LoginController", "DemoController" }; + + var controllers = types.Where(p => p.Name.Contains("Controller") && !noController.Contains(p.Name)); + foreach (var type in controllers) { - if (type.Name.Length > 10 && type.BaseType.Name == "ControllerBase" && type.Name.EndsWith("Controller")) //如果是Controller + if (type.Name.Length > 10 && type.BaseType.Name == "Controller" && type.Name.EndsWith("Controller")) //如果是Controller { var members = type.GetMethods(); var cp = new ControllerPermission @@ -50,30 +54,37 @@ namespace CoreCms.Net.Filter cp.name += "【" + cp.description + "】"; } - foreach (var member in members) + + var newMembers = members.Where(p => + p.ReturnType.Name == "ActionResult" || p.ReturnType.Name == "FileResult" || + p.ReturnType.Name == "JsonResult" || (p.ReturnType.GenericTypeArguments.Length > 0 && p.ReturnType.GenericTypeArguments[0].Name == "JsonResult")).ToList(); + + foreach (var member in newMembers) { - if (member.Name == "ValidationProblem") continue; + if (member.Name == "ValidationProblem" || member.Name =="Json") continue; + + //if (member.ReturnType.Name == "ActionResult" || member.ReturnType.Name == "FileResult" || member.ReturnType.Name == "JsonResult" || (member.ReturnType.GenericTypeArguments.Length > 0 && member.ReturnType.GenericTypeArguments[0].Name == "JsonResult")) //如果是Action + //{ + //} - if (member.ReturnType.Name == "ActionResult" || member.ReturnType.Name == "FileResult" || member.ReturnType.Name == "JsonResult" || (member.ReturnType.GenericTypeArguments.Length > 0 && member.ReturnType.GenericTypeArguments[0].Name == "JsonResult")) //如果是Action + + var ap = new ActionPermission { - var ap = new ActionPermission - { - name = member.Name, - actionName = member.Name, - controllerName = member.DeclaringType.Name.Substring(0, member.DeclaringType.Name.Length - 10) - }; - // 去掉“Controller”后缀 - - var attrs = member.GetCustomAttributes(typeof(DescriptionAttribute), true); - if (attrs.Length > 0) ap.description = (attrs[0] as DescriptionAttribute).Description; - - if (!string.IsNullOrEmpty(ap.description)) - { - ap.name += "【" + ap.description + "】"; - } - cp.action.Add(ap); + name = member.Name, + actionName = member.Name, + controllerName = member.DeclaringType.Name.Substring(0, member.DeclaringType.Name.Length - 10) + }; + // 去掉“Controller”后缀 + + var attrs = member.GetCustomAttributes(typeof(DescriptionAttribute), true); + if (attrs.Length > 0) ap.description = (attrs[0] as DescriptionAttribute).Description; + if (!string.IsNullOrEmpty(ap.description)) + { + ap.name += "【" + ap.description + "】"; } + cp.action.Add(ap); + } cp.action = cp.action.Distinct(new ModelComparer()).ToList(); result.Add(cp);