博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CYQ.Data 正式支持 DotNET Core 版本发布
阅读量:6387 次
发布时间:2019-06-23

本文共 5054 字,大约阅读时间需要 16 分钟。

闲话几句:

自从上周开始,IOS人员逝去,就开始接手IOS的代码了。

并开始整理IOS的代码(包括当时一开始设计的开发框架)。

在未来不远的日子里,设想是有一个系列详细的介绍I恋App和IT连App及前后端所有涉及的技术系列。

同时还准备发布一个IOS的开发框架,为十二星座再凑一个成员。

闲话结束,下面看正文: 

CYQ.Data 支持DotNet Coe 的折腾过程:

大约是上周五,在提交CYQ.Data V5.5.8.1版本到Nuget后,看着C盘还有7G发了一会呆。

之后做了一个决定,卸载了VS2015,现在C盘有10个G。

到了微软官网,下载了社区版,把VS2017给装上了,好在可以选组件,只挑.NET Core 相关的,5个多G就完事。

 

   

安装好之后,建一个类库工程,把整套源码Copy过去,依赖项就是我们平时引用dll的地方:

开始编绎,并见证奇迹:一堆错误。

 

还好,VS2017在错误提示方面很人性化,分批给你显示错误数,让你解决一批再出来一批。

不像当初在VS2015折腾.NET Core 1.1的时候,一下子出来几百个错误,梁静如都救不了你。

面对错误:怎么处理、支持Dotnet Core ?

折腾.NET Core 1.1的时候:

那时候是把CYQ.Data的源码给重构整理了一次,把不支持的都单独给抽离出来。

像这样,比如那时候不支持序列化,就把涉及序列化的都抽出来放到一个文件:

通常一个类,会分拆出几个partial的部分类(不支持的用于被排除)

 

想法挺好:

通过排除某些文件夹的方式,来达到切换的状态,这样可以不用维护两份代码。

但是:

要达到去掉文件夹还能编绎完整通过的解O方式,由于有些是强关系,关是业务整理,工作量大的出奇。

一些代码还得修改为反射的动态调用,才能达到分离文件也正常,好不麻烦。

关键还是那时候的版本缺失的类库太多,折腾没几天,放下了,回头才是岸。

 

折腾.NET Core 2.0:

1:想过针对性的写一个迷你版本。

但没那么简单,要有激情,要有大量时间,这些条件要同时满足不容易。

同时意味着又多一个要维护的框架,虽然我维护中的框架已数不过来,多一个也不算多。

可时间对于认真的人,总是不够用啊!!!

 

2:通过增量方式,解决版本支持问题

上面说到,折腾 .NET Core 1.1 时,是想通过减量排除来解决问题,结果不得其门。

事情放一放,一回头,解决问题的方式,就是来的那么巧,那么妙。

这回很理所当然的,就想到用增量的方式来解决问题。

CYQ.Data 如何通过增量代码支持.NET Core

对于每一个提示不存在的类,VS环境中鼠标放上去时,都会有一个提示重构,通过它可以减少不少工作量。

1:为每一个不支持的类、方法、或属性,都用重构的方式,重新生成一个类文件,并用对应的名称空间整理放好。

通过这种方式,整理出不支持有差异化的类库,而且也可以清楚知道,框架里引用了哪些类是 .NET Core所没有的。

然后先顺利编绎通过。

 

2:重写新建类库的实现,比如,重写读配置文件:

using CYQ.Data;using System.IO;using CYQ.Data.Tool;using System.Collections.Specialized;namespace System.Configuration{    internal class ConfigurationManager    {        static string appSettingJson = string.Empty;        static ConfigurationManager()        {            string filePath = AppConfig.WebRootPath + "appsettings.json";            if (System.IO.File.Exists(filePath))            {                appSettingJson = File.ReadAllText(filePath, Text.Encoding.UTF8);                if (!string.IsNullOrEmpty(appSettingJson))                {                    appSettingJson = appSettingJson.Replace("\\\\", "\\");                }            }        }        private static NameValueCollection _AppSettings;        public static NameValueCollection AppSettings        {            get            {                if (_AppSettings == null && !string.IsNullOrEmpty(appSettingJson))                {                    string settingValue = JsonHelper.GetValue(appSettingJson, "appsettings");                    if (!string.IsNullOrEmpty(settingValue))                    {                        _AppSettings = JsonHelper.ToEntity
(settingValue); } } if (_AppSettings == null) { return new NameValueCollection(); } return _AppSettings; } } private static ConnectionStringSettingsCollection _ConnectionStrings; public static ConnectionStringSettingsCollection ConnectionStrings { get { if (_ConnectionStrings == null) { _ConnectionStrings = new ConnectionStringSettingsCollection(); if (!string.IsNullOrEmpty(appSettingJson)) { string settingValue = JsonHelper.GetValue(appSettingJson, "connectionStrings"); if (!string.IsNullOrEmpty(settingValue)) { NameValueCollection nv = JsonHelper.ToEntity
(settingValue); if (nv != null && nv.Count > 0) { foreach (string key in nv.Keys) { ConnectionStringSettings cs = new ConnectionStringSettings(); cs.Name = key; cs.ConnectionString = nv[key]; _ConnectionStrings.Add(cs); } } } } } return _ConnectionStrings; } } }}  

配置文件和System.Web这两个是经常用到的东西。

相对配置文件的读取,System.Web的,麻烦了一些,需要Nuget上引用Microsoft.AspNetCore:

 

引用好后,再重写里面的内容,具体的内容,这里就不贴代码了,代码可以见源码处。

由于这周末两天临时集中处理,刚处理好,只做了简单的MSSQL的测试。

所以来不及发布Nuget上,先写文了,等哪天测试稳定了再上Nuget。

CYQ.Data 支持.NET Core 的方法:

1:GitHub下载CYQ.Data的源码(会发现多了一个文件夹)

地址:

 

由于目前还没提交解决方案文件可以直接运行项目,所以现在提前提前体验的需要自己建类库项目了:

2:自己新建一个类库项目,取名叫CYQ.Data,把源码都Copy过去(包括DotNetCore)

3:Nuget上引用Microsoft.AspNetCore。

编绎,然后就大功告成了,在你的.NET Core 项目里引用类库项目就可以了。

如果涉及到Web,还需要有两个注入的地方:

在MVC项目中调用app.UseStaticHttpContext()。        public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory)        {            app.UseStaticHttpContext();            .....	 }在没有注入 HttpContextAccessor的项目中,还需在ConfigureServices 方法中调用services.AddHttpContextAccessor();

 

 

总结:

一个周末,一个巧合,一个连续的激情奋战。

CYQ.Data 的.NET Core支持工作,就这样告一段落了。

测试了MSSQL是基本通过,剩下的都好说了!!!

后面Taurus.MVC还是Aries,估计离支持.NET Core也不远了。

 

不过,接下来,又要进入IT连创业的状态了。

对于IT连,结合一些网友的建议,最近也有不少思考。

对接下来的产品优化及走向,又一波伤脑估计是在所难免。

另外,运营还缺的一篇文章,回头也还得补上。

最后的最后,仍是感谢大伙的关注!!!

转载地址:http://kudha.baihongyu.com/

你可能感兴趣的文章
如何学习PHP整个体系的?
查看>>
css三角形实现写法全攻略收集
查看>>
Enterprise and the press public MBT Fora
查看>>
js常用代码整理
查看>>
富文本编辑器TinyMCE
查看>>
01_vue实例_数据_方法
查看>>
“穿越”——正则表达式
查看>>
使用 find 命令实现高级排除需求
查看>>
【DEV GridControl】怎样使GridView中满足某个条件的行可编辑,其余行不可编辑?...
查看>>
一只年轻而倒悬的梨
查看>>
解决time_wait过多的问题
查看>>
技术转载:Jni学习一:了解Jni
查看>>
vue教程2-07 自定义指令
查看>>
Node.js之循环依赖
查看>>
python3调用阿里云短信服务
查看>>
Linux-百度云之AccleriderMini使用
查看>>
bootstrapTable refresh 方法使用简单举例
查看>>
2、TestNG+Maven+IDEA环境搭建
查看>>
maven插件运行过程中自动执行sql文件
查看>>
New UWP Community Toolkit - XAML Brushes
查看>>