2019-02-27 ASP.NetCore+EFCore AP

2019-02-27  本文已影响0人  淡淡的忧伤005

项目技术栈

    ASP.Net Core(2.1.1) + EntityFrameworkCore(2.1.1 DBFirst<SQLServer>)  IDE VS2017 

Nuget

      nuget 发音为(new get)   是个包管理器. 个人理解 相当于 maven 之于 JAVA, cocoaPod之于iOS, npm 之于 Node,类似的还有 Swift的 Swift Package Manager 总之就是管理依赖的一个工具.

新建项目如图示

新建API项目

先不进行身份验证和 HTTPS

取消勾选HTTPS,先玩基本的

项目结构如下:

先找main函数

注册服务的地方

配置服务

我自己建的项目结构(有点混搭的风格, IBL Service, Model,C#,JAVA,iOS各个的影子都能看到 羞羞).不管了,能跑代码就行

混搭风的项目结构

配置EntityFrameWork的Nuget 包

工具 > Nuget包管理器 > 管理解决方案的Nuget程序包

默认引用的依赖是这3个

默认包

搜索EntityFrameworkCore 选择项目,选择版本 2.1.1(和ASP.netCore的版本号一致),点击安装

安装EFCore的nuget包

安装完成

安装完成

DBFirst 所以你的先有个库(废话) 准备好连接字符串 开始根据DB生成Entity和Context

工具 > Nuget包管理器 > 程序包管理器控制台 输入命令

Scaffold-DbContext -Connection "Server=ip地址;Database=数据库名;uid=haha;pwd=123456" Microsoft.EntityFrameworkCore.SqlServer -OutputDir "Models\Entity"

一阵命令行狂闪,你的Entity就建好了(微软爸爸好厉害)

根据数据库生成实体

这个是生成的dbContext

注意13行的方法,用它来注入

先配置连接字符串

连接字符串

注册服务,一定要用 AddScoped <详见一个URL,回头再找>

注册DBContext

下面就是一顿注入了

假如我们要写一个用户登录的服务,给UserController用

需要 写一个UserService 实现 IUserService的接口 (此时UserService 要读取数据库,需要注入 dbContext)

UserController里需要注入UserService 

添加 新建项 类

新建项

加上俩注解  [Route("api/user/")]

    [ApiController] 一个是管路由的,一个是让他成为控制器类的

控制器内的注入

注入自定义的service

注入自定义的service

自定义服务里提供注入 DBContext的入口

提供注入 DBContext的入口

实现

实现

F5调试,就会调起 IISExpress 打开你的默认浏览器 

launch

psotman 跑一下

post

剩下的就是发布了

.netCore默认是随机端口号的,真正生产环境是需要指定端口号的

1.新建一个配置文件 hosting.json (名字随便起)

2.读取配置文件,让程序监听指定端口

3.发布 dotnet publish (会生成FirstAPI.dll和相应的其他文件)

4.cd到发布成功的路径 dotnet FirstAPI.dll

.新建一个配置文件 hosting.json (这个json文件改完一定要保存啊,我没保存结果屡次不生效)

为啥字段叫server.urls,需要看源码

读取配置文件并使用配置

读取配置文件并使用配置

好了剩下的就是 打包发布了

找到 程序包管理控制台 输入dotnet publish

publish

cd到 publish文件夹

dotnet FirstAPI.dll

运行dll

用postMan试一下(不知为啥,8105不行,在mac上是可以的)

ok

验证一下跨平台

发给mac

pulish

cd到dll所在的文件夹(不cd到所在文件夹 会报连接字符串为null的哦)

结果说我mac上版本过低 需要2.1.1 本机2.1.0(结果一顿升级)

cd到dll所在的文件夹

run一下试试

OK

流水账记完

上一篇下一篇

猜你喜欢

热点阅读