微软在2019年9月24日发布了dotNet Core 3.0和C# 8.0,添加了许多新Features,详情点我。无疑dotNet Core 3.0和一个月之后即将发布的dotNet Core 3.1对于dotNet来说是一个重要的里程碑。

对于MySQL而言,现在越来越多的商业公司使用MySQL来作为自己的主要数据库,虽然MySQL已经迎来了8.0的版本,有着更完善的数据能力,更好的性能,但是还是有很多公司在新项目上使用MySQL5.7。我在技术上很鄙视这样的做法,一旦使用的老技术Out of support,对已有项目的改动和迁移所做的努力将会是当初学习新和试错的N倍。

言归正传,今天来记录一下使用dotNet Core 3.0的WebAPI和MySQL 8.0的使用(本次实践基于已有数据库,没有完成数据库的需要使用Workbench或Navicat搭建数据库)。

  1. 准备工作

准备工作的目的是搭建一个便于我们调试的工程环境。考虑到以后用到微服务的可能,这里并不能用硬编码(Hardcoding)写死启动的地址和端口,以下工作就是为了达到指定端口启动的目的。

  1. 建立工程

    平常一些小项目我都用VS Code来创建工程了,但这次我使用Visual Studio 2019 16.3.5(dotNet Core 3.0需要至少16.3的版本,如果用VS Code需要最新的C#插件)创建工程。

    为了日后上微服务可能,我们并不能写死项目的启动地址和端口;而且得益于dotNet Core自带Kestrel,所以我并不打算使用IIS Express作为调试使用。在"解决方案次源管理器"中右击项目名——"属性"——"调试"——"配置文件"中选择项目名对应项——"启动"选择"项目",""应用程序参数先不填,这个后面会用到。

     

  2. 添加启动参数

    要想指定地址和端口启动,我们可以用硬编码;也可以读取Json配置;也可以像我一样,在程序启动时传入参数。下面介绍如何通过重写Program.cs来读取程序的启动参数。

    可以删除CreateHostBuilder方法,并填加如下方法:

    1. public static IWebHost BuildWebHost(string[] args)  
    2. {  
    3.     var config = new ConfigurationBuilder()  
    4.     .AddCommandLine(args)  
    5.     .Build();  
    6.     string ip = config["ip"];  
    7.     string port = config["port"];  
    8.     Console.WriteLine($"ip={ip}:port={port}");  
    9.     return WebHost.CreateDefaultBuilder(args)  
    10.     .UseStartup<Startup>()  
    11.     .UseUrls($"http://{ip}:{port}")  
    12.     .Build();  
    13. }  

    修改Main方法为:

    1. public static void Main(string[] args)  
    2. {  
    3.     BuildWebHost(args).Run();  
    4. }  

     

    在项目"属性"页——"调试"选项卡——"应用程序参数"中填写相应参数,例如我这里填写"—ip 127.0.0.1 –port 8000"。

    在调试按钮的下拉选项中选择项目名。

    到此,按F5或Ctrl+F5启动调试,浏览器会跳转到我们指定的地址和端口。

    1. 添加数据库

    官方教程并没有给出添加MySQL的实例,但其过程和SQL Server是一样的。

  3. 准备工作

    添加NuGet包:在"程序包管理器控制台"中键入:

    dotnet add package MySql.Data.EntityFrameworkCore --version 8.0.18

    我并没有使用Pomelo库,而用的是MySQL官方库,截止到当天是8.0.18。

    创建如下几个目录:

    Data——用来存放数据库上下文等数据文件

    Models——用来存放数据模型

  4. 创建模型

    在Models目录下创建与数据库匹配的数据模型TestModel.cs。如要指定主键,可以用[Key]属性在模型中指定。

    1. using System;    
    2. using System.ComponentModel.DataAnnotations;    
    3. namespace LRMS.Server    
    4. {    
    5.     public class TestModel    
    6.     {    
    7.         [Key]    
    8.         public int uid { getset; }    
    9.         public string username { getset; }    
    10.         public string password { getset; }    
    11.     }    
    12. }  

     

  5. 创建数据库上下文

    在Data目录下创建数据库上下文TestDbContext.cs。在上下文中使用EF Core中的DbSet类型创建对应的与数据表名称(可忽略大小写)相应的实例。

    1. using Microsoft.EntityFrameworkCore;    
    2. namespace LRMS.Server    
    3. {    
    4.     public class UserInfoDbContext : DbContext    
    5.     {    
    6.         public UserInfoDbContext(DbContextOptions options) : base(options) { }    
    7.         public DbSet<TestModel> User_Login { getset; }    
    8.     }    
    9. }    
  6. 添加数据库连接字

    打开在工程的根目录下的appsettings.json。替换以下对象:

    1. {  
    2.     "ConnectionStrings": {  
    3.         "连接字名称": "Server=数据库地址;uid=数据库账户;pwd=数据库密码;database=数据库Schema;charset=utf8;SslMode=None;",  
    4.     },  
    5.     "Logging": {  
    6.         "LogLevel": {  
    7.             "Default": "Information",  
    8.             "Microsoft": "Warning",  
    9.             "Microsoft.Hosting.Lifetime": "Information"  
    10.         }  
    11.     },  
    12.     "AllowedHosts": "*"  
    13. }  

     

    打开Startup.cs,在CoinfigureServices方法中添加如下代码:

    1. public void ConfigureServices(IServiceCollection services)  
    2. {  
    3.     services.AddControllers();  
    4.     services.AddDbContext<UserInfoDbContext>(options =>  
    5.     {  
    6.         options.UseMySQL(Configuration.GetConnectionString("连接字名称"));  
    7.     });  
    8. }  

    到此,数据库的使用部分结束了。

    1. 后续

    为了安全,防止泄漏,在控制器中我们并不能直接使用数据库上下文,下面的代码展示了一种简单的处理。

    1. // 创建私有、只读的数据库上下文实例  
    2. private readonly UserInfoDbContext _db;  
    3. // 构造函数中为其赋值  
    4. public UserLoginController(UserInfoDbContext db)  
    5. {  
    6.     _db = db;  
    7. }  

     

    以上。

.Net Core 3.0 WebAPI && MySQL 8.0搭建详情的更多相关文章

  1. docker安装MySQL 8.0及初始化错误处理

      Preface          Several days ago,I've implement a docker environmnet,I'm gonna Install a MySQL 8. ...

  2. MySQL与MariaDB核心特性比较详细版v1.0(覆盖mysql 8.0/mariadb 10.3,包括优化、功能及维护)

    注:本文严禁任何形式的转载,原文使用word编写,为了大家阅读方便,提供pdf版下载. MySQL与MariaDB主要特性比较详细版v1.0(不含HA).pdf 链接:https://pan.baid ...

  3. Nacos使用 MySQL 8.0 提示Public Key Retrieval is not allowed

    原因如下(参考官网给出的连接选项): 如果用户使用了 sha256_password 认证,密码在传输过程中必须使用 TLS 协议保护,但是如果 RSA 公钥不可用,可以使用服务器提供的公钥:可以在连 ...

  4. 记一次使用Asp.Net Core WebApi 5.0+Dapper+Mysql+Redis+Docker的开发过程

    #前言 我可能有三年没怎么碰C#了,目前的工作是在全职搞前端,最近有时间抽空看了一下Asp.net Core,Core版本号都到了5.0了,也越来越好用了,下面将记录一下这几天以来使用Asp.Net ...

  5. ASP.NET Core 3.0 WebApi 系列【2】.Net Core 3.0+ CodeFirst + MySql 实现数据的迁移

    写在前面 在前一小节中,我们创建了基于RESFULL风格的服务.这个小节,尝试使用CodeFirst+MySql 的方式实现数据迁移. 一.开发环境 [1]运行环境:win10 家庭版 [2]开发工具 ...

  6. ASP.NET Core 3.0 WebApi 系列【1】创建ASP.NET Core WebApi 项目

    目录 写在前面 一.运行环境 二.项目搭建 三.测试 API 四.基础知识 五.写在最后 写在前面 C#语言可以创建RESTful服务,被称作WebApi.在这里总结学习使用支持创建.读取.更新.删除 ...

  7. .net core 2.0 webapi部署iis操作

    1.安装 .net core 2.0 runtime, (dotnet-runtime-2.0.7-win-x64.exe) https://www.microsoft.com/net/downloa ...

  8. asp.net core 2.0 webapi集成signalr

    asp.net core 2.0 webapi集成signalr   在博客园也很多年了,一直未曾分享过什么东西,也没有写过博客,但自己也是汲取着博客园的知识成长的: 这两天想着不能这么无私,最近.N ...

  9. ASP.NET Core 3.0 WebApi中使用Swagger生成API文档简介

    参考地址,官网:https://docs.microsoft.com/zh-cn/aspnet/core/tutorials/getting-started-with-swashbuckle?view ...

随机推荐

  1. MyCat教程六:全局序列号-全局主键的自增长

      前面我们介绍了MyCat的分库分表操作,那么同一张表中的数据会被保存在不同的数据库中,那么这就涉及到了主键维护的问题,此时肯定不能使用单个数据库中id自增的方式来处理了,这时我们就可以通过MyCa ...

  2. [Linux] nginx的try_files指令实现隐藏index.php的重写

    1.nginx的try_files指令 ,核心功能是替代rewrite,并且比rewrite更强大的是可以按顺序查找文件是否存在,如果文件都找不到才会执行最后的重定向解决的问题是,如果一个网站的部署是 ...

  3. 常用.gitignore

    android开发 关键词:java,android,androidstudio 地址:https://www.gitignore.io/api/java,android,androidstudio ...

  4. 使用GCP_EC2云服务器搭部署网络服务

    首先,在此阿里云/腾讯云/华为云购买一个云服务器推荐使用阿里云的 首先链接你的VPS,可以使用X-shell / Putty / SecureCRTPortable 等SSH链接工具 注意:如果不知道 ...

  5. 201871010110-李华《面向对象程序设计(java)》第十六周学习总结

    博文正文开头格式:(2分) 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https://www.cnblogs.co ...

  6. selenium 2定位方式实例

    #########百度输入框的定位方式########## #通过id方式定位 browser.find_element_by_id("kw").send_keys("s ...

  7. Mysql基础知识--视图

    一.视图的操作 为了提高SQL语句的复用性和操作表的安全性,,MySQL数据库管理系统5提供了视图特性. 视图:本质上是一种虚拟表,其内容与真实的表相似,包含一系列带有名称的行和列数据.但是视图并不在 ...

  8. 链接doc命令行的mysql的编码问题

    好几次用doc命令行链接mysql数据库进行保存注册等内容,一直出错,要么插入数据库的是乱码问题,要么是没插进去,怎么回事? 在修改了代码(接收中文数据)的基础上(即在代码中用utf-8接收数据) 也 ...

  9. C# 一般处理程序

    public class Three : IHttpHandler{ public void ProcessRequest(HttpContext context) { context.Respons ...

  10. 41 修改树莓派交换分区 SWAP 的大小

    http://blog.lxx1.com/3289 SWAP就是LINUX下的虚拟内存分区,它的作用是在物理内存使用完之后,将磁盘空间(也就是SWAP分区)虚拟成内存来使用.它和Windows系统的交 ...