我想使用 Visual Studio 2012 For Web 创建一个网站,它有一个数据库和一个生成的 UI,例如我们使用模板项目时所拥有的:
动态数据实体 Web 应用程序
但我也想有一个登录页面,例如模板项目提供的:
Asp.Net Web 表单应用程序
我发现这些模板非常适合这些任务中的任何一个,但如果你想要它们两个都非常糟糕。
如果我从动态数据实体 Web 应用程序模板开始,那么我可以在数据库端获得很棒的页面,只需很少的编码工作 - 但我无法让登录代码正常工作(另外,我认为我不应该编写无论如何,该代码,因为它已经存在于 Asp.Net Web 表单应用程序中)。每当我尝试时,我都会陷入可怕的混乱。我真的不想了解身份验证、成员资格和 cookie 或“它是如何做到的”或任何类似的东西。我想要的是让 .Net 框架处理所有这些,并告诉我查看页面的人的用户名是什么。就这样。有一种方法可以使用 Asp.Net Web Forms Application 模板。
但是,如果我从 Asp.Net Web Forms Application 模板开始,那么登录的东西就可以开箱即用......但是我在尝试为数据库创建 UI 时陷入了可怕的混乱!但鉴于该代码已存在于动态数据实体 Web 应用程序模板中,这应该不是必需的。同样,我真的不想学习它是如何做到的,我只是想用它来为我做这些事情,这样我就不必这样做了。我不想告诉它如何更新、删除等……我也不需要动态数据实体 Web 应用程序模板,但是我无法获取登录信息。
无论如何,我认为这是一项非常简单的任务,我已经扯掉了大部分头发:使用 Code First Entities 方法使用简单的数据库创建一个登录/注册的网站。我的经验是,如果你想拥有一个数据库但没有登录,那么你就是在笑。如果你想登录但没有数据库 UI,那你就笑了。如果你想要两者兼得,那么除非你是一个超级骗子微软技术专家,生活和呼吸这些东西......或者你知道“技巧”(可能存在于某个论坛的某个地方),否则你将面临很多痛苦。
无论如何,我的问题是,我在这里缺少什么?是否有一个网站包含一大堆其他模板,其中包含将 Web 表单(具有自动登录/成员资格控制)与动态数据实体 Web 应用程序相结合的模板,该应用程序在显示表格和允许编辑方面做得很好?我很难相信 Microsoft 打算让我知道如何完成 Dynamic Data Entities Web Application 和 Asp.Net Web Forms Application 所做的所有事情,才能获得这两种功能。
我花了一周的时间才弄清楚如何让“启用迁移”在 Web 表单模板类型中工作......基本上每一个小步骤都是一场巨大的战斗,需要一个又一个论坛阅读以发现小“技巧”。但最后,我真正想要的只是一个将动态数据实体 Web 应用程序功能(即数据驱动的网页)与 Web 表单功能(即用户登录)相结合并在 Azure 上发布的模板。我以为这很简单。但事实证明这是一场噩梦,事实上我完全被困住了。
更新:
按照http://msdn.microsoft.com/en-us/library/ee923692(v=vs.100).aspx上的建议,我又花了半天时间试图让它工作。但这对我不起作用。它不应该那么复杂。制作这样一种常见的网站格式不需要那种程度的修修补补:带有 UI 和登录的数据库。
现在我回到几天前遇到的第一个问题,不知何故消失了,但我不知道如何:
PM> Enable-Migrations System.ArgumentException:参数不正确。(来自 HRESULT 的异常:0x80070057 (E_INVALIDARG))
服务器堆栈跟踪:在 System.Runtime.Remoting.Messaging.StackBuilderSink._PrivateProcessMessage(IntPtr md, Object[] args, Object server, Object[]& outArgs) 在 System.Runtime.Remoting 的 EnvDTE.Properties.Item(Object index) .Messaging.StackBuilderSink.SyncProcessMessage(IMessage 消息)
在 [0] 处重新引发异常:在 EnvDTE.Properties 的 System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke(MessageData& msgData, Int32 type) 处的 System.Runtime.Remoting.Proxies.RealProxy.HandleReturnMessage(IMessage reqMsg, IMessage retMsg)。 System.Data.Entity.Migrations.MigrationsDomainCommand.GetFacade(String configurationTypeName) 在 System.Data. System.Data.Entity.Migrations.EnableMigrationsCommand.<>c_DisplayClass2 .<.ctor>b处的 Entity.Migrations.EnableMigrationsCommand.FindContextToEnable(String contextTypeName)_0() at System.Data.Entity.Migrations.MigrationsDomainCommand.Execute(Action command) 参数不正确。(来自 HRESULT 的异常:0x80070057 (E_INVALIDARG))
在这一点上,我要放弃了。我不得不放弃,因为经过一周的尝试,我可以设法在 Azure 上创建一个有数据库和 UI 但没有登录名的网站,或者在 Azure 上创建一个有登录名但没有数据库 UI 的网站。对我来说,为我的每一个表创建一个网格视图,并手动连接 RowChange、UpdateMethod、DeleteMethod 等(即不使用动态数据脚手架)将是荒谬的,因为脚手架存在(它只是除非我从一开始就使用该模板,否则很难让它工作,但是如果我使用该模板,那么我就没有登录页面!)。无论如何,现在这个“参数不正确”的错误再次弹出,所以我在转圈。