利用C++开发一个迷你的英文单词录入和测试小程序-升级版本

我们现在有了一个本地sqlite3的迷你英文单词小测试工具,需求就跟工作当中一样是不断变更的。这里虚构两个场景,并且一步一步的完成最终升级后的小demo。

场景:数据不依赖本地sqlite3,需要支持远程访问,用目前的restful api来实现

总体设计

这里我们需要做一个迷你的restful的服务端,并且优化本地的代码,从以前请求本地sqlite3,变成restful 请求,并且还能支持原先本地sqlite3。需要代码尽可能的容忍需求的变化。

详细设计:

为了能适应本地sqlite3和restful api访问,我们需要来一次简单的抽象,把业务层的接口给抽象出来,这样利用派生类来构建sqlite3的实现和restful api 的实现,然后重构下状态机,面向接口编程。这样就能还好的应对这里的需求,即使后续迁移到mysql,es等等都不在话下。

面向接口重构代码

先抽象接口,我们主要有几个业务查询函数,查询所有数据,查询some数据,添加数据,以及更新数据

sqlite3的实现

为了复用代码之前的sqlite3作为一个成员,构造的时候打开数据库

添加

查询一些数据

有了这两个类,我们搞个factory来构建这样的对象出来。然后再之前的状态机里面全部利用接口来操作。

原先直接调用manager的代码编程操作接口

测试状态机主要代码

然后再构造函数里面构造正确的对象

到这里我们有个面向接口的重构版本

添加restful api接口实现

继承一个新的派生类,很显然这里是调用restapi,来完成对应的功能。这里我们还是继续使用cpprestsdk来完成。

我们先定义三个辅助函数,更新类似这里不再重复。

添加

查询一些

备注:按正常的开发顺序,其实应该先整服务器端,然后再编码c++ client部分。

服务器端代码

这里可选择路子很多,python,java spinrtboot,node等等,这里挑选从来没玩过的nodejs来整。毕竟就是为了了解点新的知识。

node 开发一个restful 百度下,一般是推荐express来整。直接参考demo来搞

引入express 和validator,验证数据,以及实现restful功能

在开始写之前,我们先要把sqlite3远端的node代码写出来,老样子,定义一个模块

连接数据库,执行sql语句,然后导出函数

在app.js里面,引入。然后就是写接口对应的几个实现代码

返回所有数据

返回一些数据

添加数据

到这里服务器基本完成,建议服务器单独用postman 配合nodejs 来整,不要直接和c++对接,不然问题会发散,烧脑。到这里服务端和客户端都有了。在工厂函数里面构造对应的对象,就自动适应了需求变化,可能这也就是写代码前需要先思考,设计的魅力所在。

demo

题外话

关于字符编码,字符编码可能花费了我写这个小工具很多时间,一会是string转wstring,一会是utf-8转gb2312(为了显示)。总结下来,1,需要知道当前的string 是什么编码,然后目标是什么编码,然后找对应的函数;2. vs 这里因为区域设置,使用的GB2312,所以utf8需要转换成GB2312才能正确的显示中文。3. web是不是都是utf8?

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值