第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

使用EF Database First MVC5的ASP.NET標(biāo)識(shí)

使用EF Database First MVC5的ASP.NET標(biāo)識(shí)

翻翻過去那場(chǎng)雪 2019-08-30 17:57:32
是否可以將新的Asp.net標(biāo)識(shí)與Database First和EDMX一起使用?或者只使用代碼?這是我做的:1)我創(chuàng)建了一個(gè)新的MVC5項(xiàng)目并讓新的Identity在我的數(shù)據(jù)庫中創(chuàng)建了新的User和Roles表。2)然后我打開了我的Database First EDMX文件并拖入了新的Identity Users表,因?yàn)槲矣衅渌c之相關(guān)的表。3)保存EDMX后,Database First POCO生成器將自動(dòng)創(chuàng)建User類。但是,UserManager和RoleManager需要從新的Identity命名空間(Microsoft.AspNet.Identity.IUser)繼承User類,因此使用POCO User類將不起作用。我想一個(gè)可能的解決方案是編輯我的POCO生成類以使我的User類繼承自IUser?或者ASP.NET Identity僅與Code First Design兼容?++++++++++++++++++++++++++++++++++++++++++++++++++ ++++++++++++更新:根據(jù)Anders Abel的建議,這就是我所做的。它的工作原理,但我想知道是否有更優(yōu)雅的解決方案。1)我通過在與自動(dòng)生成的實(shí)體相同的命名空間中創(chuàng)建一個(gè)部分類來擴(kuò)展我的實(shí)體User類。namespace MVC5.DBFirst.Entity{    public partial class AspNetUser : IdentityUser    {    }}2)我將DataContext更改為繼承IdentityDBContext而不是DBContext。請(qǐng)注意,每次更新EDMX并重新生成DBContext和Entity類時(shí),都必須將其設(shè)置為此。 public partial class MVC5Test_DBEntities : IdentityDbContext<AspNetUser>  //DbContext3)在自動(dòng)生成的User實(shí)體類中,必須將override關(guān)鍵字添加到以下4個(gè)字段中,或者將這些字段注釋掉,因?yàn)樗鼈兪菑腎dentityUser繼承的(步驟1)。請(qǐng)注意,每次更新EDMX并重新生成DBContext和Entity類時(shí),都必須將其設(shè)置為此。    override public string Id { get; set; }    override public string UserName { get; set; }    override public string PasswordHash { get; set; }    override public string SecurityStamp { get; set; }
查看完整描述

3 回答

?
慕的地8271018

TA貢獻(xiàn)1796條經(jīng)驗(yàn) 獲得超4個(gè)贊

應(yīng)該可以將身份系統(tǒng)與POCO和Database First一起使用,但您必須進(jìn)行一些調(diào)整:


更新.tt文件以生成POCO以生成實(shí)體類partial。這將使您可以在單獨(dú)的文件中提供其他實(shí)現(xiàn)。

User在另一個(gè)文件中部分實(shí)現(xiàn)該類

 


partial User : IUser

{

}

這將使User類實(shí)現(xiàn)正確的接口,而不會(huì)觸及實(shí)際生成的文件(編輯生成的文件總是一個(gè)壞主意)。


查看完整回答
反對(duì) 回復(fù) 2019-08-30
?
夢(mèng)里花落0921

TA貢獻(xiàn)1772條經(jīng)驗(yàn) 獲得超6個(gè)贊

我的步驟非常相似,但我想分享。


1)創(chuàng)建一個(gè)新的MVC5項(xiàng)目


2)創(chuàng)建一個(gè)新的Model.edmx。即使它是一個(gè)新的數(shù)據(jù)庫,也沒有表。


3)編輯web.config并替換生成的connectionstring:


<add name="DefaultConnection" connectionString="Data Source=(LocalDb)\v11.0;AttachDbFilename=|DataDirectory|\aspnet-SSFInventory-20140521115734.mdf;Initial Catalog=aspnet-SSFInventory-20140521115734;Integrated Security=True" providerName="System.Data.SqlClient" />

使用此連接字符串:


<add name="DefaultConnection" connectionString="Data Source=.\SQLExpress;database=SSFInventory;integrated security=true;" providerName="System.Data.SqlClient" />

然后,構(gòu)建并運(yùn)行應(yīng)用程序。注冊(cè)用戶,然后將創(chuàng)建表。


查看完整回答
反對(duì) 回復(fù) 2019-08-30
  • 3 回答
  • 0 關(guān)注
  • 621 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)