项目技术栈
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 总之就是管理依赖的一个工具.
新建项目如图示
先不进行身份验证和 HTTPS
项目结构如下:
注册服务的地方
我自己建的项目结构(有点混搭的风格, IBL Service, Model,C#,JAVA,iOS各个的影子都能看到 羞羞).不管了,能跑代码就行
配置EntityFrameWork的Nuget 包
工具 > Nuget包管理器 > 管理解决方案的Nuget程序包
默认引用的依赖是这3个
搜索EntityFrameworkCore 选择项目,选择版本 2.1.1(和ASP.netCore的版本号一致),点击安装
安装完成
DBFirst 所以你的先有个库(废话) 准备好连接字符串 开始根据DB生成Entity和Context
工具 > Nuget包管理器 > 程序包管理器控制台 输入命令
Scaffold-DbContext -Connection "Server=ip地址;Database=数据库名;uid=haha;pwd=123456" Microsoft.EntityFrameworkCore.SqlServer -OutputDir "Models\Entity"
一阵命令行狂闪,你的Entity就建好了(微软爸爸好厉害)
这个是生成的dbContext
先配置连接字符串
注册服务,一定要用 AddScoped <详见一个URL,回头再找>
下面就是一顿注入了
假如我们要写一个用户登录的服务,给UserController用
需要 写一个UserService 实现 IUserService的接口 (此时UserService 要读取数据库,需要注入 dbContext)
UserController里需要注入UserService
添加 新建项 类
加上俩注解 [Route("api/user/")]
[ApiController] 一个是管路由的,一个是让他成为控制器类的
注入自定义的service
自定义服务里提供注入 DBContext的入口
实现
F5调试,就会调起 IISExpress 打开你的默认浏览器
psotman 跑一下
剩下的就是发布了
.netCore默认是随机端口号的,真正生产环境是需要指定端口号的
1.新建一个配置文件 hosting.json (名字随便起)
2.读取配置文件,让程序监听指定端口
3.发布 dotnet publish (会生成FirstAPI.dll和相应的其他文件)
4.cd到发布成功的路径 dotnet FirstAPI.dll
.新建一个配置文件 hosting.json (这个json文件改完一定要保存啊,我没保存结果屡次不生效)
读取配置文件并使用配置
好了剩下的就是 打包发布了
找到 程序包管理控制台 输入dotnet publish
cd到 publish文件夹
dotnet FirstAPI.dll
用postMan试一下(不知为啥,8105不行,在mac上是可以的)
验证一下跨平台
发给mac
cd到dll所在的文件夹(不cd到所在文件夹 会报连接字符串为null的哦)
结果说我mac上版本过低 需要2.1.1 本机2.1.0(结果一顿升级)
run一下试试
流水账记完