今天终于做了第一个任务,学习API之后的第一个实例。销售设置开发API。

第一、层次结构

1.API各层

项目结构主要有五层,分别为API、BizModel、Data、DBModel、Logic。

2.各层作用

首先对于微服务架构来说,前后端分离,后端提供数据支撑,前端UI通过API获取数据。

API为controller接收参数,controller层不做任何逻辑处理,只是通过Model接收参数,调用Logic进行逻辑处理。

BizModel为对应前端UI的实体数据模型。我们都知道DBModel是对应数据库字段的实体数据模型,而BizModel对应UI控件。例如:一个User,包含ID、username、password、email等字段,而前端可能控件不只是对应填写User的字段,可能填写此User的同学、家人的信息,则DBModel就无法对应。所以BizModel为前端传递数据,可以对应多个DBModel中的字段。BizModel通过Logic分成DBModel再进行SQL动作。

Data层进行数据库读写动作。

DBModel为实体数据模型。

Logic为逻辑层,对BizModel分离为DBModel,调用Data层执行读写动作。

第二、API构建

1.对应数据表字段构建DBModel

查看需要进行操作的数据表,对应字段写入

public class PreferenceModel
{
public Guid AdminUserKey { get; set; }
public string MsCCode { get; set; }
public int ShippingAddressSource { get; set; }
public bool Audit1 { get; set; }
public bool Audit2 { get; set; }
public int AutoFeedBack { get; set; }
public int eBayMsgSHowlines { get; set; }
public bool DirectSalesAudit1 { get; set; }
public bool DirectSalesAudit2 { get; set; }
public bool NewTemplate { get; set; }
}

2.对应UI传参构建BizModel

public class PreferenceEntity
{
public Guid AdminUserKey { get; set; }
public string MsCCode { get; set; }
public int? ShippingAddressSource { get; set; }
public bool? Audit1 { get; set; }
public bool? Audit2 { get; set; }
public int? AutoFeedBack { get; set; }
public int? eBayMsgSHowlines { get; set; }
public bool? DirectSalesAudit1 { get; set; }
public bool? DirectSalesAudit2 { get; set; }
public bool? NewTemplate { get; set; }
}

3.Data层数据库读写方法

在此不做详细展示,自行处理即可。

4.Logic层处理逻辑,并调用Data层方法进行动作

这里讲一下更新的逻辑,在项目中销售设置分为两个页面,三个更新动作,对应同一个数据表。所以逻辑不是很复杂,但是想要更新不同数据,又不影响其他数据,只用一个API,就要进行一定处理。

原本我的想法是Data层三个方法分别进行更新,在Logic层进行区分,这种方法不是不可以,但是本着精简易维护的原则,只使用一个方法更新,逻辑层进行处理。所以思路是controller接收参数调用Logic,将参数通过Entity传递给Logic,然后在Logic判断如果某一字段的参数并未传递新值,则使用原数据值进行更新。思路正确,下一步实施。

遇到问题int、bool类型字段不能判断非空,所以不知道int型默认的0和bool型默认的false是不是传递过来的值。

解决方法:在BizModel将bool和int定义为bool?和int?,使用隐形,就可以判断变量是否为空,如果不为空,再将参数强制转换,进行数据更新。

5.Controller定义

API只有GET、PUT、POST、DELETE方法,为了规范,Controller命名必须规范。Controller接收参数,调用Logic返回数据。

至此,API的主要构建已完成,接下来Build查看是否有错误,无错误试运行,进入Swagger测试。

测试成功后发布,发布完成使用Postman进行测试。

WebAPI实例--第一个API的更多相关文章

  1. 实现单实例多线程安全API问题

    前阵子写静态lib导出单实例多线程安全API时,出现了CRITICAL_SECTION初始化太晚的问题,之后查看了错误的资料,引导向了错误的理解,以至于今天凌晨看到另一份代码,也不多想的以为singl ...

  2. ASP.NET Core WebApi使用Swagger生成api说明文档看这篇就够了

    引言 在使用asp.net core 进行api开发完成后,书写api说明文档对于程序员来说想必是件很痛苦的事情吧,但文档又必须写,而且文档的格式如果没有具体要求的话,最终完成的文档则完全取决于开发者 ...

  3. 第十二节:WebApi自动生成在线Api文档的两种方式

    一. WebApi自带生成api文档 1. 说明 通过观察,发现WebApi项目中Area文件夹下有一个HelpPage文件夹,如下图,该文件夹就是WebApi自带的生成Api的方式,如果该文件夹没了 ...

  4. ASP.NET Core WebApi使用Swagger生成api

    引言 在使用asp.net core 进行api开发完成后,书写api说明文档对于程序员来说想必是件很痛苦的事情吧,但文档又必须写,而且文档的格式如果没有具体要求的话,最终完成的文档则完全取决于开发者 ...

  5. ASP.NET Core WebApi使用Swagger生成api说明文档

    1. Swagger是什么? Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格的 Web 服务.总体目标是使客户端和文件系统作为服务器以同样的速度来更新.文件 ...

  6. 微服务Kong(三)——添加一个API

    在开始前,请确保您已经安装了KONG服务,并且已经启动了KONG服务. 在本节中,您可以学习到:如何在KONG层添加一个API.这是您使用KONG来管理您的API的第一步.对于此篇教程,我们将使用 h ...

  7. 【转】ASP.NET Core WebApi使用Swagger生成api说明文档看这篇就够了

    原文链接:https://www.cnblogs.com/yilezhu/p/9241261.html 引言 在使用asp.net core 进行api开发完成后,书写api说明文档对于程序员来说想必 ...

  8. Flask一分钟Mock一个API

    如果安装了Python,并且安装了Flask: pip install flask 那么就可以在短短一分钟内Mock出来一个API,而且只需要用到一个文件. 彻底告别在线Mock网站无法指定请求方法, ...

  9. 每天一个JavaScript实例-从一个div元素删除一个段落

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

随机推荐

  1. ccf-20160903--炉石传说

    本题思路如下图: 题目和代码如下: 问题描述 试题编号: 201609-3 试题名称: 炉石传说 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 <炉石传说:魔兽英雄传& ...

  2. HighCharts初测试

    把HighChart嵌入到博客中.  

  3. 【转】ICCAVR TAB键设置

    转载于: http://blog.163.com/liuyunqian@yeah/blog/static/7039584320099159545292/ 在使用ICCAVR C编译器的时候会发现TAB ...

  4. java中的深复制和浅复制

    Java 语言的一个优点就是取消了指针的概念,但也导致了许多程序员在编程中常常忽略了对象与引用的区别,本文会试图澄清这一概念.并且由于Java不能通过简单 的赋值来解决对象复制的问题,在开发过程中,也 ...

  5. SQL查询语句,怎样查询重复数据

    SQL查询语句,怎样查询重复数据 2012-02-22 14:50神奇的马骁勇 | 浏览 0 次 有表A, 中有字段id, name, memo现在有很多id重复的数据,怎么把这些重复的都查出来?gr ...

  6. magento2.2.5安装

    首先肯定要去下载源码,然后配置虚拟主机访问,例:http://magento.cn 这里我们采用命令行安装: php bin/magento setup:install --admin-firstna ...

  7. Spark远程调试参数

    Spark远程调试脚本: #调试Master,在master节点的spark-env.sh中添加SPARK_MASTER_OPTS变量 export SPARK_MASTER_OPTS="- ...

  8. oracle11g设置归档模式和非归档模式

    1.首先查看当前数据库是否处于归档模式            可使用如下两种方式查看 1.1  select name, log_mode from v$database;   log_mode的值为 ...

  9. gitlab分支代码本地拉取及jenkins关联gitlab分支

    git本地拉取 git init git remote add origin http://47.*.*.*:8089/back_dev/claimeureka.git git fetch origi ...

  10. 提示文件过大无法复制到U盘怎么解决

    1.U盘作为一个便携的移动存储工具,在我们的生活中扮演重要的角色,但 是我们经常会遇到在复制文件到U盘中的时候,U盘明显有很大的空间,却 提示文件过大无法复制,今天,我教大家一步解决这个问题!! 2. ...