一、背景
其实就是很简单的,公司会桌面开发的人员紧缺啊,项目又赶,而我们公司的前端人员人多还厉害(ps:吐槽下,后端的人真的少啊,会桌面开发的更少啊),所以萌生出了使用html+js来构建本地应用程序,但是我们的客户基本都是制造行业,需要对很多硬件进行交互(IO卡、PLC、串口等等各种),那就势必还是需要传统的应用程序(毕竟方案多),emmm,那这两者之间需要怎么样结合呢?so就有了本文,让winform变成一个httpserver,这样就可以接入各种硬件以及处理耗时动作,将界面跟业务处理分开,当时这个还是前端人员提出能不能用前端技术构建界面,后面我们一合计,应该是可以试试(ps:大佬们如果有问题请轻拍啊)
二、技术点说明
websocket-sharp
websocket-sharp是开源的websocket的C#封装,可以帮助我们快速构建websocket的相关应用,但是同时它也提供了httpserver的功能,这次选型这个的缘故也是因为有websocket的存在,后续扩展做实时的数据交互应该是非常方便的
其他:
autofac(IOC使用)、json.net(json序列化使用)
三、关注点
如图所示,对于一个自动更新程序,关注点应该都是以上几个点
- 支持Get以及Post请求,这个应该是基本的(对于其他请求没有进行封装)
- 依赖注入,还是很好用的,最直观的就是不用写new对象了
- 异常filter,可以实现全局异常捕获以及处理(服务端开发应该用的比较多)
- 文件获取,最直观的就是要显示图片咋办
- 自定义filter,就是平常我们针对于每个action的拦截器(目前还未实现)
大致应该就以上几点,如果实现以上几点,应该可以算是一个像模像样的简陋版httpserver(只支持api访问的那种)
四、设计流程图
一些说明:
1、为了减少依赖,我将websocket-sharp的源码全部放入到MHttpServer项目中,感谢websocket-sharp的作者,可以让我方便的实现httpserver的功能
2、整体流程就如上所示,应该还是比较顺畅,我目前是把自己做服务器端开发时候的一些惯性思路带到这个项目中,有可能会不符合其他人的开发习惯
3、其他具体看github的代码,如果有人想做研究的话
4、程序考虑支持XP,所以将.net framework的版本定在4.0,所以autofac的版本是比较低的,这个如果需要最新版本可以自己去升级
5、整体的开发参照目前WebApi的方式进行,路由规则定为controller/action(例如:User/Add),所以是没有参照restful的标准(实际原因是理解不了Restful怎么应付复杂的http请求场景,例如参数个数类型一样的情况下??)
五、如何使用
新建winform项目后,在需要开启的地方里加入以下代码:
MHttpServer.Listen listen = new MHttpServer.Listen(8088); ContainerBuilder builder = new ContainerBuilder(); builder.RegisterType().PropertiesAutowired(); listen.InitController(builder); listen.start();
以上代码是实例化一个httpserver对象,并且将service注入到buid中,将build传入到InitController,通过这种方式实现全局的依赖注入
效果如下:
正常执行,并且触发更新winform的界面,TestDo方法是一个事件,事件中将收到的数据显示在form的richtextbox中
故意触发异常执行:
触发异常执行的时候,如下图所示,进入了ExceptionFilter中,并且将处理过的异常返回到前端
六、总结
这次的实践只是一个新的尝试,如果效果比较好的话,后续对于交互要求比较高的程序,应该都会采用这种方案进行,通过NanUI或者electron构建界面,本地开启httpserver进行硬件的交互以及业务上的数据查询,充分发挥团队中每个人的作用
这个项目中的大部分东西都是第三方开源产品,我只是做了一个封装,所以最后感谢开源这些产品的作者们
由于个人原因,在测试上可能会有所不够,如果有什么bug的话,还请告知,感谢(ps:文字表达弱鸡,多多包涵)
项目地址:https://github.com/Hello-Mango/MHttpServer
作者: Mango
出处: http://www.cnblogs.com/OMango/
关于自己:专注.Net桌面开发以及Web后台开发,开始接触微服务、docker等互联网相关(最近被互联网架构搞的死去活来- -)
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接,如有问题, 可站内信告知.