.NetCore 下开发独立的(RPL)含有界面的组件包 (六)实现业务功能
.NetCore 下开发独立的(RPL)含有界面的组件包 (一)准备工作
.NetCore 下开发独立的(RPL)含有界面的组件包 (二)扩展中间件及服 务
.NetCore 下开发独立的(RPL)含有界面的组件包 (三)构建界面
.NetCore 下开发独立的(RPL)含有界面的组件包 (四)授权过滤
.NetCore 下开发独立的(RPL)含有界面的组件包 (五)授权过滤参数处 理
.NetCore 下开发独立的(RPL)含有界面的组件包 (六)实现业务功能
这里们来做一个简单的业务列表功能,这里我就先来做一个Cient列表
一如以往,先添加页面

当然需要在界面上写上我们的列表语法,razorview会处理@符号的后台代码,这里我们制定了我们的数据源是dataSoure,当然这里是会报错的,但是没关系,因为最后执行都是ClientsIndex.Designer.cs类
@foreach (var item in dataSource)
{
<tr>
<td>
<div class="layui-unselect layui-form-checkbox" lay-skin="primary" data-id='@item.ClientId'><i class="layui-icon"></i></div>
</td>
<td>@item.ClientName</td> <td class="td-manage">
<a href="javascript:;" title="编辑" ><i class="layui-icon"> </i>编辑</a>
<a href="javascript:;" title="删除" ><i class="layui-icon"> </i>删除</a> </td>
</tr>
}
运行命令 dotnet razorpagegenerator IdentityServer4.AdminChina 生成下视图
可以看到生成是视图代码,淡然这里的dataSource是找不到的,可以在视图上加上一些命名空间的引用以及写好的服务的操作代码,后面就不需要在视图类中去修改了
foreach (var item in dataSource)
{ #line default
#line hidden
WriteLiteral(" <tr>\r\n <td>\r\n <div class=\"layui-unselect layui-form-checkbox\" lay-skin=\"primary\" data-id=\'");
#line 56 "ClientsIndex.cshtml"
Write(item.ClientId); #line default
#line hidden
WriteLiteral("\'><i class=\"layui-icon\"></i></div>\r\n </td>\r\n <td>");
#line 58 "ClientsIndex.cshtml"
Write(item.ClientName); #line default
#line hidden
WriteLiteral(@"</td> <td class=""td-manage"">
<a href=""javascript:;"" title=""编辑"" ><i class=""layui-icon""> </i>编辑</a>
<a href=""javascript:;"" title=""删除"" ><i class=""layui-icon""> </i>删除</a> </td>
</tr>
");
下面就们就来为我们的dataSource做准备了
构建服务相关类

接口中定义个获取数据的方法
public interface ICustomClientServies
{
List<ClientModel> GetClients();
}
public class CustomClientServies : ICustomClientServies
{
//private readonly XXXDbContext _dbContext
//public CustomClientServies(XXXDbContext dbContext)
//{
// _dbContext = dbContext;
//}
public List<ClientModel> GetClients()
{
return new List<ClientModel>
{
new ClientModel{ ClientId=, ClientName="Implicit" },
new ClientModel{ ClientId=,ClientName="Hybrid" },
new ClientModel{ClientId=, ClientName="ClientCredintials" },
new ClientModel{ClientId=, ClientName="AuthorizationCode" },
};
}
}
这里实现我就不操作数据库了,如果需要操作数据库或者使用IdentityServer4的上下文对象都是可以的,如上面注释部分一样,这里添加几条模拟数据,写了这些还不够,我们还需要将我们的Client服务DI
所以这里我们还需要扩展IServiceCollection对象,这里我们在扩展类中添加这个扩展,淡然你也可以写对IIdentityServerBuilder(IdentityServer4)的扩展
public static IServiceCollection AddAdminChina(this IServiceCollection services)
{
services.AddScoped<ICustomClientServies, CustomClientServies>();
return services;
}
接下来我们来视图类中处理我们的服务类,说到这里我们来看下BaseView这个视图基类里面都有什么?
protected HttpContext Context { get; private set; }
/// <summary>
/// The request
/// </summary>
protected HttpRequest Request { get; private set; }
/// <summary>
/// The response
/// </summary>
public HttpResponse Response { get; private set; }
下面这三个对象都是BaseView提供给我们的,而我们的视图类继承了这个基类,所以可以想到从RequestServices拿到服务就轻而易举了,接下来修改代码,在视图类中添加对datasource的构造,这样数据就应该没有问题了,我种类就写一个列表了,当然如果你要分页,接受参数 ,判断 获取身份信息状态等等都能搞定,就因为有上面的上个对象,当然如果你中间件获取了使用用户的敏感信息,那么你这个中间件肯定就不安全了,比如你获取access_token之类的操作
var services = Request.HttpContext.RequestServices.GetService(typeof(ICustomClientServies)) as ICustomClientServies;
var dataSource = services.GetClients();
var services = Request.HttpContext.RequestServices.GetService(typeof(ICustomClientServies)) as ICustomClientServies;
var dataSource = services.GetClients();
foreach (var item in dataSource)
{ #line default
#line hidden
WriteLiteral(" <tr>\r\n <td>\r\n <div class=\"layui-unselect layui-form-checkbox\" lay-skin=\"primary\" data-id=\'");
#line 58 "ClientsIndex.cshtml"
Write(item.ClientId); #line default
#line hidden
WriteLiteral("\'><i class=\"layui-icon\"></i></div>\r\n </td>\r\n <td>");
#line 60 "ClientsIndex.cshtml"
Write(item.ClientName);
最后一步在中间件中加上我们的Client视图路由,这里就不贴了,然后我们在WebTest服务中添加服务扩展
public void ConfigureServices(IServiceCollection services)
{
services.AddAdminChina();
}
这里去掉上一篇中的根据参数判断权限的代码,实际操作不会这么处理,毕竟其他的路由地址不会携带这个参数,以及在视图中添加好我们的服务用与生成视图类。还有就是中间件地址需要动态处理,这就不多说了,下面看下实际的效果,访问我们的Client管理 列表页面就出来了

好了,关于这块的就说了,相信写一个独立的RPL包应该不是问题了
.NetCore 下开发独立的(RPL)含有界面的组件包 (六)实现业务功能的更多相关文章
- .NetCore 下开发独立的(RPL)含有界面的组件包 (五)授权过滤参数处理
.NetCore 下开发独立的(RPL)含有界面的组件包 (一)准备工作 .NetCore 下开发独立的(RPL)含有界面的组件包 (二)扩展中间件及服 务 .NetCore 下开发独立的(RPL)含 ...
- .NetCore 下开发独立的(RPL)含有界面的组件包 (四)授权过滤
.NetCore 下开发独立的(RPL)含有界面的组件包 (一)准备工作 .NetCore 下开发独立的(RPL)含有界面的组件包 (二)扩展中间件及服 务 .NetCore 下开发独立的(RPL)含 ...
- .NetCore 下开发独立的(RPL)含有界面的组件包 (三)构建界面
.NetCore 下开发独立的(RPL)含有界面的组件包 (一)准备工作 .NetCore 下开发独立的(RPL)含有界面的组件包 (二)扩展中间件及服 务 .NetCore 下开发独立的(RPL)含 ...
- .NetCore 下开发独立的(RPL)含有界面的组件包 (二)扩展中间件及服务
.NetCore 下开发独立的(RPL)含有界面的组件包 (一)准备工作 .NetCore 下开发独立的(RPL)含有界面的组件包 (二)扩展中间件及服 务 .NetCore 下开发独立的(RPL)含 ...
- .NetCore 下开发独立的(RPL)含有界面的组件包 (一)准备工作
.NetCore 下开发独立的(RPL)含有界面的组件包 (一)准备工作 .NetCore 下开发独立的(RPL)含有界面的组件包 (二)扩展中间件及服 务 .NetCore 下开发独立的(RPL)含 ...
- Razor Page Library:开发独立通用RPL(内嵌wwwroot资源文件夹)
ASP.NET Core知多少系列:总体介绍及目录 Demo路径:GitHub-RPL.Demo 1. Introduction Razor Page Library 是ASP.NET Core 2. ...
- 关于在Java EE 下开发web,出现项目中的外部包没有tomcat的包的原因
在新建的项目的时候,要设置目标服务器运行环境,把那个设置成tomcat,这样,项目中就会有tomca的api
- 在桌面Linux环境下开发图形界面程序的方案对比
在Linux下开发GUI程序的方法有很多,比如Gnome桌面使用GTK+作为默认的图形界面库,KDE桌面使用Qt作为默认的图形界面库,wxWidgets则是另一个使用广泛的图形库,此外使用Java中的 ...
- .netcore下的微服务、容器、运维、自动化发布
原文:.netcore下的微服务.容器.运维.自动化发布 微服务 1.1 基本概念 1.1.1 什么是微服务? 微服务架构是SOA思想某一种具体实现.是一种将单应用程序作为一套小型 ...
随机推荐
- 基于ATT和CK™框架的开放式方法评估网络安全产品
场景 提供有关如何使用特定商业安全产品来检测已知对手行为的客观见解 提供有关安全产品和服务真实功能的透明度以检测已知的对手行为 推动安全供应商社区增强其检测已知对手行为的能力 地址 https://a ...
- python用WMI模块获取系统命名空间
可以和winmgmts的查询页面对应 from win32com.client import GetObject import pywintypes result=[] def enum_namesp ...
- BZOJ2038 [2009国家集训队]小Z的袜子 莫队+分块
作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中找出一双来穿.终于有一天,小Z再也无法忍受这恼人的找袜子过程,于是他决定听天由命…… 具体来说,小Z把这N只袜子从1到N编号,然后从 ...
- css效果文字多了就...
开发中经常会遇见这样的问题,一段文字或者一段标题过长了,就让超出长度的部分益...替换.具体怎么做的呢?直接上代码: <style> *{ margin: 0; padding: 0; } ...
- 前端lvs访问多台nginx代理服务时出现404错误的处理
前端lvs访问多台nginx代理服务时出现404错误的处理 环境描述:app --> lvs --> nginx --> server app访问页面购买流量页面(nginx服务器) ...
- Laravel资源理由器跟隐式控制的对比及是怎样的吧?- Route::resource vs Route::controller
stackoverflow找到的问题:http://stackoverflow.com/questions/23505875/laravel-routeresource-vs-routecontrol ...
- 35)django-验证码
一:验证码原理 第一次访问GET,后台: 1.创建一张图片 2.在图片中写入随机字符串 3.将图片写到制定文件 4.打开指定目录文件,读取内容 5.把生成的验证码保存在session中 6. 通过Ht ...
- 5)django-模板
django模板显示页面 一:语法使用 1)变量:{{变量名}} 2)for循环 {% for row in userlist%} ...
- MySql两种存储引擎的区别
MyISAM是MySQL的默认数据库引擎(5.5版之前),由早期的ISAM(Indexed Sequential Access Method:有索引的顺序访问方法)所改良.虽然性能极佳,但却有一个缺点 ...
- 锤子科技"临死前"被"接盘" ,内部人士爆料已改签今日头条母公司
就在昨天,据据锤子科技内部人士透露,部分锤子科技员工在昨天已经接到了相关的临时通知,要求改签劳动合同至今日头条的母公司——字节跳动.至于这是锤子科技真正再度复活还是借尸还魂都不重要,重要的是,作为忠实 ...