在工作中,我们常常会遇到许多需要完成的小功能点。以我自己的工作情况为例,最常见的是两个方面:1、控制台项目;2、web界面(纯前端)。
首先让我们讨论控制台项目的工作内容。在没有使用PostMan之前,工作中大量使用接口调用。在项目准备阶段,首先需要对接口的使用进行描述。在主要使用WebService和WCF服务接口的公司中,可以通过Visual Studio直接进行一套可视化的操作,通过代理类的方法引用接口,这真是C#开发的乐趣所在。言归正传,现在让我们详细讨论一下工作中常用的功能点:1、测试服务接口;2、编写Windows服务。
在控制台项目中完成服务接口测试的功能非常简单,本文主要强调一些常用方法。在编写类项目时,主要会使用三个类库:1、Newtonsoft.Json(JSON序列化);2、log4net(日志记录);3、NUnit(单元测试)。
从业务角度来看,无非就是调用接口进行测试,如果成功则通过,如果失败则记录日志。单元测试的主要目的是为了批量使用接口,测试接口的并发性和其他操作。
Windows服务在我的工作中主要结合任务调度使用,同时结合一些其他技术,如队列和缓存。例如:1、每隔10秒同步一次A数据库(SqlServer)数据到B数据库(Oracle),表名和字段名都不相同;2、每天凌晨2点运行一项或多项任务,成功或失败均记录日志并推送给管理员(通过手机短信、邮件、内部服务平台)。
这些大多是结合任务调度来完成的,通常使用Quartz.Net进行任务调度,将控制台服务转换为Windows服务使用Topshelf,日志记录使用log4net。通过这三个组件,我的一般需求就能得到满足,其他功能点根据需要引用不同的类库。
接下来是简单的项目搭建。项目搭建1.0:新建一个控制台项目,运行环境选择.NET Framework 4.5。
新建解决方案:

首先引用Nuget包,不同的层引用不同的Nuget,再次简单说明一下:
- Common:基础层
- Models:实体层
- Schedules:调度层
进行不同的模块封装。
log4net的引用和封装:log4net不需要做太多的封装,只需提供一个初始化和一个获取日志接口的方法即可。
public class LogFactory
{
static LogFactory()
{
string path = AppDomain.CurrentDomain.BaseDirectory + @"/log4net.config";
FileInfo configFile = new FileInfo(path);
log4net.Config.XmlConfigurator.Configure();
}
public static ILog GetLogger(string name)
{
return LogManager.GetLogger(name);
}
public static ILog GetLogger(Type type)
{
return LogManager.GetLogger(type);
}
}最简单的log4net配置文件:
至此,log4net的工作就完成了。
Newtonsoft.Json:

版本随意选择。在编程过程中经常会使用JSON的序列化和反序列化,编写一个简单的帮助类:
////// Json帮助类 /// public class JsonHelper { ////// 将对象序列化为JSON格式 /// /// 对象 ///json字符串 public static string SerializeObject(object o) { string json = JsonConvert.SerializeObject(o); return json; } ////// 解析JSON字符串生成对象实体 /// ///对象类型 /// json字符串(eg.{"ID":"112","Name":"石子儿"}) ///对象实体 public static T DeserializeJsonToObject(string json) where T : class { JsonSerializer serializer = new JsonSerializer(); StringReader sr = new StringReader(json); object o = serializer.Deserialize(new JsonTextReader(sr), typeof(T)); T t = o as T; return t; } /// /// 解析JSON数组生成对象实体集合 /// ///对象类型 /// json数组字符串(eg.[{"ID":"112","Name":"石子儿"}]) ///对象实体集合 public static ListDeserializeJsonToList (string json) where T : class { JsonSerializer serializer = new JsonSerializer(); StringReader sr = new StringReader(json); object o = serializer.Deserialize(new JsonTextReader(sr), typeof(List )); List list = o as List ; return list; } /// /// 反序列化JSON到给定的匿名对象. /// ///匿名对象类型 /// json字符串 /// 匿名对象 ///匿名对象 public static T DeserializeAnonymousType(string json, T anonymousTypeObject) { T t = JsonConvert.DeserializeAnonymousType(json, anonymousTypeObject); return t; } }










