上次我们做了单点登录和注销登录。那时候登录的数据都是死的,我们要想从数据库获取数据,
当然就要用ef 生成,获取数据。
一,新建一个.net core 的mvc项目
新建好项目后,不能像以前一样直接在新建项中添加ef了,需要用命令在添加ef的依赖
注意:所以依赖注入的命令不要放在项目里,要选择放入自己需要生成数据的类库里。
二,需要使用工具的Nuget包管理器添加EF的依赖。
Install-Package Microsoft.EntityFrameworkCore.SqlServer
三.如果是使用db first,需要根据数据库生成model,就还需要使用命令添加两个依赖
Install-Package Microsoft.EntityFrameworkCore.Tools Install-Package Microsoft.EntityFrameworkCore.SqlServer.Design
四.相关依赖注入成功之后,就可以再根据一个命令从数据库生成model了
Scaffold-DbContext "Server=.;Database=Food;Trusted_Connection=True;" Microsoft.EntityFrameworkCore.SqlServer -OutputDir Models
注意:这里的Database=数据库的名称
依赖注入安装这个依赖的时候他会提示:你的版本太低,
因为系统是win7,powershell版本太低了,不支持这个命令,需要安装3.0以上的powershell版本才行
不用慌,我们这里有网站教程,大家可以查看教程升级版本。
https://www.cnblogs.com/tshaoguo/p/10142743.html
注意:我们在存放Windows6.1-KB2506143-x64.cab包的时候,要对应自己电脑的路径存放使用哦,不要直接复制网站路径。
然后我们再次使用命令·即可:
Scaffold-DbContext "Server=.;Database=HouseDB;Trusted_Connection=True;" Microsoft.EntityFrameworkCore.SqlServer -OutputDir Models
还有一种情况,就是有些电脑的版本和powershell3.0版本有些不太兼容。当你在注入生成model的命令之后会报版本冲突问题。
没有报错的可以忽略此段内容。
不用慌,我们也有解决方案。就是在Nu Get 包管理器的解决方案Nu Get程序包配置一下这几个版本为2.1.0。
Microsoft.EntityFrameworkCoreMicrosoft.EntityFrameworkCore.SqlServerMicrosoft.EntityFrameworkCore.ToolsMicrosoft.VisualStudio.Web.CodeGeneration.Design以第一个为例,配置,图如下:
四个都是一样的分别复制后,在NuGet解决方案里搜索,然后都配置为2.1.0版本,然后安装就行。效果图如下:
我当时就是遇到第二种情况,后来重做登录也是报版本冲突问题,后面就重新安装版本后就好啦,不容易啊。
好啦,现在解决版本问题,ef也依赖注入完成,我们就需要获取数据库的数据了,这里net core 里的ef 和net mvc 还是有区别的哦。
当我们得到model数据层之后,就需要在类库封装用户登录的方法。
定义数据源,封装同步和异步登录的方法,代码如下:
public class UserDAL : IUserDAL { private readonly HouseDBContext _houseDBContext; //构造函数,得到数据源 public UserDAL(HouseDBContext MyhouseDBContext) { _houseDBContext = MyhouseDBContext; } //用户登录的方法 同步 public Customers Login(string username, string password) { Customers customer = _houseDBContext.Customers.Where(a => a.LoginName == username && a.Password == password).FirstOrDefault(); return customer; } //用户登录的方法 :异步 public Task<Customers> LoginAsync(string username, string password) { Task.Run(() => { Customers customer = _houseDBContext.Customers.Where(a => a.LoginName == username && a.Password == password).FirstOrDefault(); return customer; }); return null; }
大家是不是发现我们这个类还继承了一个借口:IUserDAL。
1,就是我们需要在类库里新建两个文件夹,Implemts,Interface,把UserDAL类移到Implemts后,选择UserDAL类右键快速操作和重构接口
2,把重构的类移到Interface的文件夹中。然后更改两个的命名空间即可,如图。
五.现在我们需要在项目的Startup.cs服务的ConfigureServices方法里配置连接数据库
服务添加用户继承的接口:配置依赖注入的关系 services.AddTransient<IUserDAL, UserDAL>(); services.AddDbContext<HouseDBContext>(option => { option.UseSqlServer("Data Source =.; Initial Catalog = HouseDB; User ID = sa; Password = 123456"); });
注意:连接数据库的配置不能错了哦。
最后一步。我们需要在登录项目的Account控制器下获取数据.
tip:因为net core 不允许实例化对象,所以只有定义获取值。
我们调用同步登录的方法,验证登录。代码如下图:
到这一步终于完成啦,好累好累。现在大家可以登录试试,如果输入错误的用户名或密码就会报错哦,大家也可以自己调试一下过程,
毕竟好不容易做出来的,虽然外表看上去只是一个小小的ef获取数据登录。哈哈!
不懂的,欢迎在评论区讨论问题哦。