4、加入数据库支持

下面我们为项目加入数据库支持,修改appsettings.json:

然后我们要生成实体类,打开VS工具->NuGet包管理器->程序包管理器控制台:

输入命令:

Scaffold-DbContext "server=.;userid=root;pwd=root;port=3306;database=chainstore;sslmode=none;" Pomelo.EntityFrameworkCore.MySql -OutputDir Models -Force

回车执行时会提示错误:

是因为我们没有引入MySQL的支持包,我们在依赖项上点击鼠标右键,选择“管理NuGet程序包”:

注意,程序包源要切换为:nuget.org

然后我们搜索:entityframeworkcore

选择Microsoft.EntityFrameworkCore,目前最新版本是2.2.4,但由于我们Microsoft.AspNetCore.App版本是2.1.1的,需要 Microsoft.EntityFrameworkCore (>= 2.1.1 && < 2.2.0),所以我们选择2.1.8版本,点安装按钮进行安装。

然后再搜索关键字:mysql:

选择Pomelo.EntityFrameworkCore.MySql,目前最新版本是2.2.0,同样由于Microsoft.AspNetCore.App版本所限,我们只能使用2.1.4版本,点安装按钮进行安装。

然后,我们再返回程序包管理器控制台,重新执行上次的命令:

好,这次成功了,我们看到Models目录多了两个文件:

打开chainsotreContext.cs,我们将OnConfiguring方法删除,引为我们要在配置文件中配置MySQL的连接字符串,而不是直接写到类中:

然后解决一个命名规则冲突:

C#建议的类名为大写字母开头,而自动生成的类为小写字母,我们直接点“解决名称冲突”解决一下就好了。

然后我们打开Startup.cs,引入MySql连接字符串配置:

public void ConfigureServices(IServiceCollection services)

{

string MysqlConnectionString = Configuration.GetConnectionString("MysqlConnectionString");

services.AddDbContext<ChainstoreContext>(opt => opt.UseMySql(MysqlConnectionString));

services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1);

}

我们希望增加一个基础控制器类,在其中进行一些基本的控制,比如:检查请求是否合法,防御基本的攻击等,因此我们增加一个BaseController类:

代码如下:

public class BaseController : ControllerBase

{

public readonly ChainstoreContext context;

public BaseController(ChainstoreContext _context)

{

this.context = _context;

}

}

相同的方法,我们再增加一个包含读写操作的测试控制器类TestController:

注意修改此类继承自BaseController,增加构造函数继承父类构造函数。

我们想让所有的控制器类返回统一格式的JSON字符串,所以新建一个自定义模型类ResultInfo:

增加四个字段:Code、Message、Data、CurrentTime

public class ResultInfo

{

public string Code { get; set; }

public string Message { get; set; }

public object Data { get; set; }

public DateTime CurrentTime { get; set; } = DateTime.Now;

}

Code:返回当前操作代码,0为成功

Message:返回当前操作提示信息

Data:返回当前操作相关数据

CurrentTime:返回当前服务器时间戳

然后,修改测试控制器类:

查询:

// GET: api/Test

[HttpGet]

public ResultInfo Get()

{

try

{

var result = context.TMember.Where(n => n.Id > 0);

if (null != result && result.Count() > 0)

{

return new ResultInfo() { Code = "0", Message = "成功", Data = result };

}

else

{

return new ResultInfo() { Code = "100002", Message = "未找到相应会员" };

}

}

catch (Exception e)

{

return new ResultInfo() { Code = "100001", Message = "查询会员失败:" + e.Message };

}

}

// GET: api/Test/5

[HttpGet("{id}", Name = "Get")]

public ResultInfo Get(int id)

{

try

{

var result = context.TMember.Where(n => n.Id > 0);

if (null != result && result.Count() > 0)

{

var member = result.First();

return new ResultInfo() { Code = "0", Message = "成功", Data = member };

}

else

{

return new ResultInfo() { Code = "100002", Message = "未找到相应会员" };

}

}

catch (Exception e)

{

return new ResultInfo() { Code = "100001", Message = "查询会员失败:" + e.Message };

}

}

增加:

// POST: api/Test

[HttpPost]

public ResultInfo Post([FromBody] TMember member)

{

try

{

member.GradeId = 1;

member.Status = 1;

member.Creator = "self";

member.CreateTime = DateTime.Now;

context.TMember.Add(member);

context.SaveChanges();

return new ResultInfo() { Code = "0", Message = "成功", Data = member };

}

catch (Exception e)

{

return new ResultInfo() { Code = "100003", Message = "新增会员失败:" + e.Message, Data = member };

}

}

修改:

// PUT: api/Test/5

[HttpPut("{id}")]

public ResultInfo Put(int id, [FromBody] TMember member)

{

if (id != member.Id)

{

return new ResultInfo() { Code = "100004", Message = "会员ID不一致" };

}

try

{

var result = context.TMember.Where(n => n.Id == id);

if (null != result && result.Count() > 0)

{

var editMember = result.First();

editMember.UserName = member.UserName;

editMember.Password = member.Password;

editMember.Name = member.Name;

editMember.Sex = member.Sex;

editMember.Birthday = member.Birthday;

editMember.MaritalStatus = member.MaritalStatus;

editMember.GradeId = member.GradeId;

editMember.Address = member.Address;

editMember.Phone = member.Phone;

editMember.Status = member.Status;

editMember.Modifier = member.Modifier;

context.TMember.Update(editMember);

context.SaveChanges();

return new ResultInfo() { Code = "0", Message = "成功", Data = editMember };

}

else

{

return new ResultInfo() { Code = "100006", Message = "会员不存在" };

}

}

catch (Exception e)

{

return new ResultInfo() { Code = "100005", Message = "更新会员失败:" + e.Message, Data = member };

}

}

删除:

// DELETE: api/ApiWithActions/5

[HttpDelete("{id}")]

public ResultInfo Delete(int id)

{

try

{

//删除会员

var members = context.TMember.Where(n => n.Id == id);

if (null != members && members.Count() > 0)

{

context.TMember.RemoveRange(members);

context.SaveChanges();

return new ResultInfo() { Code = "0", Message = "成功", Data = id };

}

else

{

return new ResultInfo() { Code = "100008", Message = "此会员不存在", Data = id };

}

}

catch (Exception e)

{

return new ResultInfo() { Code = "100007", Message = "删除会员失败:" + e.Message, Data = id };

}

}

错误代码我们做一下规定,前四位为控制器代码(1000),后两位为具体错误代码(01)。

现在我们运行一下看看效果:

OK,是我们想要的效果,现在会员表里没有数据,所以找不到相应会员,现在我们用Postman添加一条试试:

注意上图中红框中的项,点“Send”按钮,可以看到提交结果:

然后查看数据库:

测试POST成功,数据成功添加到数据库。

然后我们再GET一下看看是否能取到刚才添加的会员:

可以,成功返回了。

再测试一下删除:

数据库中已经没有了,成功删除:

基于.Net Core的API框架的搭建(2)的更多相关文章

  1. 基于.Net Core的API框架的搭建(1)

    目标 我们的目标是要搭建一个API控制器的项目,API控制器提供业务服务. 一.开发框架搭建 1.开发前准备 开发前,我们需要下载如下软件,安装过程略: (1) 开发工具:VS2017 (2) 数据库 ...

  2. 基于.Net Core的API框架的搭建(4)

    6.加入日志功能 日志我们选用log4net,首先引入程序包: 选择2.0.8版本安装.然后在项目根目录新增log4net的配置文件log4net.config: <?xml version=& ...

  3. 基于.Net Core的API框架的搭建(3)

    5.加入缓存支持 我们希望为项目增加缓存支持,我们选择Redis做为缓存数据库. 首先,我们在Services目录增加一个缓存接口类ICacheService: using System; using ...

  4. 基于.NET CORE微服务框架 -surging的介绍和简单示例 (开源)

    一.前言 至今为止编程开发已经11个年头,从 VB6.0,ASP时代到ASP.NET再到MVC, 从中见证了.NET技术发展,从无畏无知的懵懂少年,到现在的中年大叔,从中的酸甜苦辣也只有本人自知.随着 ...

  5. 基于.NET CORE微服务框架 -谈谈surging API网关

    1.前言 对于最近surging更新的API 网关大家也有所关注,也收到了不少反馈提出是否能介绍下Api网关,那么我们将在此篇文章中剥析下surging的Api 网关 开源地址:https://git ...

  6. 基于DotNet Core的RPC框架(一) DotBPE.RPC快速开始

    0x00 简介 DotBPE.RPC是一款基于dotnet core编写的RPC框架,而它的爸爸DotBPE,目标是实现一个开箱即用的微服务框架,但是它还差点意思,还仅仅在构思和尝试的阶段.但不管怎么 ...

  7. 基于.net core 2.0+mysql+AceAdmin搭建一套快速开发框架

    前言 .net core已经出来一段时间了,相信大家对.net core的概念已经很清楚了,这里就不再赘述.笔者目前也用.net core做过一些项目,并且将以前framework下的一些经验移植到了 ...

  8. Ocelot——初识基于.Net Core的API网关

    前言 前不久看到一篇<.NET Core 在腾讯财付通的企业级应用开发实践>,给现在研究.Net Core及想往微服务方向发展的人来了一剂强心针.于是我也就立刻去下Ocelot的源码及去阅 ...

  9. 一个轻量级的基于 .NET Core 的 ORM 框架 HSQL

    HSQL 是一种轻量级的基于 .NET Core 的数据库对象关系映射「ORM」框架 HSQL 是一种可以使用非常简单且高效的方式进行数据库操作的一种框架,通过简单的语法,使数据库操作不再成为难事.目 ...

随机推荐

  1. 全文搜索(A-2)-推荐算法

    一般来说推荐算法分为两类. 基于内容过滤的推荐: 基于协同过滤的推荐: 基于内容过滤的推荐,基于特征码描述项目. 协同过滤算法的设计基于一个假设,“和目标用户相似度高的用户,其感兴趣的物品目标用户也会 ...

  2. NYOJ-1188并集与交集,STL的灵活运用!

    并集与交集 时间限制:1000 ms  |  内存限制:65535 KB 难度:2 描述 给你两个字符串的集合A和B,让你求这两个字符串集合的并集和交集,按字典序排序后输出. 然后又给出给出两个字符串 ...

  3. [BZOJ2667][cqoi2012]模拟工厂

    [BZOJ2667][cqoi2012]模拟工厂 试题描述 有一个称为“模拟工厂”的游戏是这样的:在时刻0,工厂的生产力等于1.在每个时刻,你可以提高生产力或者生产商品.如果选择提高生产力,在下一个时 ...

  4. 面向对象:元类、异常处理(try...except...)

    元类: python中一切皆对象,意味着: 1. 都可以被引用,如 x = obj 2. 都可以被当做函数的参数传入 3. 都可以被当做函数的返回值 4. 都可以当做容器类的元素(列表.字典.元祖.集 ...

  5. 基于HttpClient4.5.2实现的HttpClient工具类

    1.maven依赖: <dependency> <groupId>org.apache.commons</groupId> <artifactId>co ...

  6. 【NOIP2017练习】论战大原题(并查集)

    题意:给定一个n个点m条边的无向图.定义一条路径的长度为路径上最小边的权值. 定义dist(i,j)为起点为i,终点为j的长度最长的路径的长度.求出第k大的dist(i,j)(i<j). 对于所 ...

  7. hdu4778(状态压缩dp)

    题意: 有G种颜色的宝石,共B袋.两个人轮流拿宝石,每次从B袋中拿一袋,把其中的所有宝石倒入一个公共容器,每袋宝石只能取一次. 当容器中有S个相同颜色的宝石时,将失去这S个宝石,当前操作者得到一个魔法 ...

  8. codevs 3498 小木棍

    3498 小木棍  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解       题目描述 Description 乔治有一些同样长的小木棍,他把这些木棍随意 ...

  9. HashSet源码分析1

    import java.util.HashSet; import java.util.Iterator; import java.util.Set; public class SetTest { pu ...

  10. Office高级威胁漏洞在野利用分析

    高级威胁漏洞背景 在高级威胁攻击中,黑客远程投递入侵客户端最喜欢的漏洞是office文档漏洞,就在刚刚结束不久的黑帽子大会上,最佳客户端安全漏洞奖颁给了CVE-2017-0199漏洞,这个漏洞是时下o ...