ASP.NET 5探险(1):Azure中配置连接字符串、独立项目执行EF7数据迁移
(此文章同时发表在本人微信公众号“dotNET每日精华文章”,欢迎右边二维码来关注。)
题记:我开始把ASP.NET 5用于生产系统开发已经有1个多月了,也填了一些坑积累了一些经验,从今天开始会陆陆续续分享给大家。
众所周知,虽然Visual Studio 2015已经进入RC了,ASP.NET 5整体上还处于beta4,所以不可避免会有很多坑。也由于ASP.NET 5的文档还不完善,所以我觉得有必要把自己的一些近一个月来使用ASP.NET 5开发产品的教训、经验或小技巧分享给大家。今天先分析两个话题。
一、在Azure的Web App(aka WebSite)中如何配置连接字符串
在之前的ASP.NET中,连接字符串是放到web.config中的ConnectionStrings下,如果Web应用部署到Azure Web App后,在Web App的配置中,填入名称相同的真实(正式)的连接字符串,在运行的时候会自动覆盖(替换)web.config中的值。
在ASP.NET 5同样也可以如法炮制,只是细节有所不同。由于在ASP.NET 5里,引入了新的配置基础结构,比如连接字符串一般配置到config.json文件的“Data:XXX:ConnectionString”,”XXX”是连接字符串的名称。所以在Azure的配置中,也只需要填写同名“XXX”的连接字符串即可。唯一遵循的约定就是连接字符串必须放到“Data:XXX:ConnectionString”中。
二、如何在独立的Class Library项目中执行Entity Framework 7的数据迁移
之前的文章介绍过如何执行Entity Framework 7的数据迁移,但是假如数据模型的类和DbContext在独立的Class Library项目中又要如何处理呢。或者说,你在独立的项目(非Web主项目,其一般包含config.json和Startup.cs)中执行“dnx . ef migration”相关命令的时候,报一个“DbContext no data storee configured”的错误,要怎么办?
其实,也很简单,只是稍微多做一步。当然首先在独立的项目中要完成基本的EF7数据迁移配置(见之前的文章)。然后,在独立的项目中也添加一个config.json文件,仅仅包含DbContext所用的“Data:XXX:ConnectionString”配置,这里的连接字符串的内容最好和主Web项目一致。再添加一个Startup.cs文件,里面仅仅包含加载配置信息和配置实体框架的代码。如下所示:
public class Startup
{
public void Configure(IApplicationBuilder app)
{
// For more information on how to configure your application, visit http://go.microsoft.com/fwlink/?LinkID=398940
var configuration = new Configuration()
.AddJsonFile("config.json"); Configuration = configuration;
} public IConfiguration Configuration { get; private set; } public void ConfigureServices(IServiceCollection services)
{
services.AddEntityFramework()
.AddSqlServer()
.AddDbContext<CoreDbContext>(options =>
options.UseSqlServer(Configuration["Data:core:ConnectionString"]));
}
}
需要这样做的原因在于,project.json中的“ef”命令依然会完整启动整个应用程序(Class Library项目作为启动项)。这一点和EF6之前的版本有着很大不同。
【更新:2015-07-04】
上面的源代码有些错误,应该是下面的(使用ASP.NET 5 beta5):
using Microsoft.AspNet.Hosting;
using Microsoft.Data.Entity;
using Microsoft.Framework.Configuration;
using Microsoft.Framework.DependencyInjection; namespace EIPCore.Models
{
public class Startup
{
public Startup(IHostingEnvironment env)
{
// For more information on how to configure your application, visit http://go.microsoft.com/fwlink/?LinkID=398940
var builder = new ConfigurationBuilder()
.AddJsonFile("config.json"); Configuration = builder.Build();
} public static IConfiguration Configuration { get; private set; } public void ConfigureServices(IServiceCollection services)
{
services.AddEntityFramework()
.AddSqlServer()
.AddDbContext<CoreDbContext>(options =>
options.UseSqlServer(Configuration["Data:core:ConnectionString"]));
}
}
}
ASP.NET 5探险(1):Azure中配置连接字符串、独立项目执行EF7数据迁移的更多相关文章
- ASP.NET MVC 5 学习教程:创建连接字符串
原文 ASP.NET MVC 5 学习教程:创建连接字符串 起飞网 ASP.NET MVC 5 学习教程目录: 添加控制器 添加视图 修改视图和布局页 控制器传递数据给视图 添加模型 创建连接字符串 ...
- .NET Core 获取数据库上下文实例的方法和配置连接字符串
目录 .NET Core 获取数据库上下文实例的方法和配置连接字符串 ASP.NET Core 注入 .NET Core 注入 无签名上下文 OnConfigure 配置 有签名上下文构造函数和自己n ...
- EF中的连接字符串
映射视图是每个实体集和关联的映射中指定的可转换的可执行表示. 包括两部分: 查询视图 表示从数据库架构转到概念架构所需的规范装换 更新视图 表示从概念模型转到数据库架构所需的规范转换 如果应用程序仅用 ...
- ASP.NET Core 在 JSON 文件中配置依赖注入
前言 在上一篇文章中写了如何在MVC中配置全局路由前缀,今天给大家介绍一下如何在在 json 文件中配置依赖注入. 在以前的 ASP.NET 4+ (MVC,Web Api,Owin,SingalR等 ...
- 转载:ASP.NET Core 在 JSON 文件中配置依赖注入
在以前的 ASP.NET 4+ (MVC,Web Api,Owin,SingalR等)时候,都是提供了专有的接口以供使用第三方的依赖注入组件,比如我们常用的会使用 Autofac.Untiy.Stri ...
- 在ASP.NET项目中的web.config文件里配置数据库连接并在程序代码中获取连接字符串
1.在<connectionStrings> 标签里添加连接 <connectionStrings> <add name="ConnectionName&q ...
- ASP.NET web.config中的连接字符串
在ASP.NET的web.config中,可以用两种方式来写连接字符串的配置. <configuration> <appSettings> <add key=" ...
- eclipse中配置maven的web项目
提高效率,一般都会使用IED如eclipse来帮助开发.eclipse中单独建立一个web项目或者是maven项目是可以通过插件很容易完成的,但是如果要结合2者,就需要先建立一个,然后再转换或使原型. ...
- 在Tomcat中配置连接池和数据源
1.DataSource接口介绍 (1)DataSource 概述 JDBC1.0原来是用DriverManager类来产生一个对数据源的连接.JDBC2.0用一种替代的方法,使用DataSource ...
随机推荐
- 关于Jquery学习的几点反思
1.应用的API插件时,先看说明文档,仔细看,多花点时间也没关系. 2.写出你要完成工作的几个步骤,细化你的工作.保证每一步结果都是正确(特别是在用你不会的东西的时候),这样看起来是在浪费时间,但是最 ...
- action 方法的访问
Action中的方法的访问: 访问Action的中的方法,默认情况下只能访问execute方法.那么多次请求就不能提交到一个Action.能不能一个模块的多次请求提交到一个Action中? * 需要使 ...
- spring mvc 重定向加传参
常用: ModelAndViewi: return new ModelAndView("redirect:/toList"); 或者 ii:return "redire ...
- iOS keyChain 的使用
详细资料,请参看苹果官方文档Keychain Services Reference . ios中的keychain,用于保存用户的机密信息,对keychain的操作有4种,就是 增,删,改,查: Se ...
- codeforces 505A. Mr. Kitayuta's Gift 解题报告
题目链接:http://codeforces.com/problemset/problem/505/A 题目意思:给出一个长度不大于10的小写英文字符串 s,问是否能通过在字符串的某个位置插入一个字母 ...
- SQL删除约束
)禁止所有表约束的SQL select 'alter table '+name+' nocheck constraint all' from sysobjects where type='U' )删除 ...
- mybatis 获取自增ID
在Mybatis Mapper文件中添加属性“useGeneratedKeys”和“keyProperty”,其中keyProperty是Java对象的属性名,而不是表格的字段名. <inser ...
- 【编程题目】一个整数数组,长度为 n,将其分为 m 份,使各份的和相等,求 m 的最大值★★ (自己没有做出来!!)
45.雅虎(运算.矩阵): 2.一个整数数组,长度为 n,将其分为 m 份,使各份的和相等,求 m 的最大值 比如{3,2,4,3,6} 可以分成 {3,2,4,3,6} m=1; {3,6}{2,4 ...
- 如何在yii的controller中调用外部action
问题: 在yii中,一个controller会包含若干个action.有时为了重用或代码管理等目的,我们希望这些action可以单独定义成一个类,然后在controller中使用.那么在yii中要如何 ...
- Linux Free命令各数字含义及Buffer和Cache的区别
Linux Free命令各数字含义及Buffer和Cache的区别 Free 命令的各数字含义 命令演示 [root@vm1 ~]# free total used free shared buffe ...