在Mac下运行ASP.NET Core应用程序
在Mac下运行ASP.NET Core应用程序
通过参照.NET Core相关官方文档,在我的Mac电脑上用Visual Studio Code创建了我的第一个ASP.NET应用。
开发环境搭建
首先要先安装.Net Core和Visual Studio Code,并且要给Visual Studio Code安装
C# extension,另外要到nodejs.org
安装Node.js和npm。
利用Yeoman搭建应用
由于我们在安装Node.js时自带的npm地址是墙外,npm install有可能没有反应或者很卡。所以本文所有的npm安装都使用了淘宝NPM镜像:
npm install cnpm -g --registry=https://registry.npm.taobao.org
data:image/s3,"s3://crabby-images/f3a15/f3a158e472e547c2de1c0b323fb2cf2ad4afc2fd" alt=""
使用npm安装必要的yeoman generators和bower。
sudo cnpm install -g yo generator-aspnet bower
data:image/s3,"s3://crabby-images/6b15e/6b15e90f1737af85e871263b24a3a255df86b127" alt=""
Yeoman的logo是一个戴帽子的男人。它其实是一个工作流,这个工作流包含了三种用来提升你构建一个Web应用的生产力和满意度的工具:
脚手架工具(yo), 构建工具(Gulp,Grunt等), 包管理工具(比如npm和Bower)。
使用yo aspnet
来运行ASP.NET Core generator,以生成一个Web Application基础模板。
yo aspnet
yo aspnet
生成的模板都是基于大家熟悉的Visual Studio 2015上的模板,这个模板维护在ASP.NET Templates project。
data:image/s3,"s3://crabby-images/9140d/9140db7099d591b2ca2fe3a3443f2fdd0b4148fe" alt=""
然后会提示What type of application do you want to create?
这里选择Web Application Basic [without Membership and Authorization]
并回车。
接着会提示Which UI framework would you like to use?
data:image/s3,"s3://crabby-images/60d7c/60d7c8fd799657ffe2c42de8ef51396e757f69f6" alt=""
这里选择Bootstrap (3.3.6) as the UI framework
并回车。
用MyFirstApp
作为应用名称并回车。如下图:
data:image/s3,"s3://crabby-images/c033b/c033b9b106811d517ab9308c86af49a2be73b87f" alt=""
data:image/s3,"s3://crabby-images/f77dc/f77dc4af91e5713618bb94099e721ffbe8632d55" alt=""
此时generator会生成项目的基础框架文件,然后提示你分别执行restore,build,run命令。
Your project is now created, you can use the following commands to get going
cd "MyFirstApp"
dotnet restore
dotnet build (optional, build will also happen with it‘s run)
dotnet run
data:image/s3,"s3://crabby-images/421cc/421cca1fefa89095ba14a017d5c8f16d672bd022" alt=""
data:image/s3,"s3://crabby-images/ebb30/ebb300758593549a95d43185b2c6265b3f154c2d" alt=""
data:image/s3,"s3://crabby-images/0ba8c/0ba8cdc545ae299ee653f8f61376259b658c18d3" alt=""
data:image/s3,"s3://crabby-images/76b74/76b743fdc53375562edbcb620307bbde1f678722" alt=""
至此,打开本地的浏览器在地址栏输入:http://localhost:5000
,即可访问你创建的第一个程序。
使用Visual Studio Code开发应用
用Visual Studio Code打开刚刚创建的项目,通过快捷键⌘⇧P
输入dot
,选择dotnet: Restore Packages
来restore必要的build和debug项目依赖。可以在VS Code中直接运行包括dotnet restore
在内的命令和所有在project.json文件中引用到的工具以及在.vscode/tasks.json
中自定义的任务。
data:image/s3,"s3://crabby-images/215f3/215f33bccfc4a68bca0dfd7bc259356e8d1b6e04" alt=""
你还可以通过快捷键⌃`调出集成在VS Code里面的控制台。
data:image/s3,"s3://crabby-images/9c5a0/9c5a0a030d40a5a4adea32ec57016a2b15067f56" alt=""
对于未被用到的using
语句会被标记一道绿色波浪线,鼠标移到上面还有显示一个黄色小灯泡,此时你可以使用⌘ .
移除它们;类和方法也会显示它们在该项目中被引用的次数;还可以通过⌘KC
来添加代码块注释,通过⌘KU
来取消注释。
data:image/s3,"s3://crabby-images/03168/0316821d7ce062e4c06d4796cf8cb90399886636" alt=""
点击VS Code左侧调试窗格中的绿色三角形的调试按钮,可能会在顶部出现一个错误提示信息:
data:image/s3,"s3://crabby-images/83a6f/83a6f550ba10c568110189aa879d63ff51440a1b" alt=""
根据错误提示可知,我们需要配置launch.json
文件里面的program
为实际的可执行文件。
data:image/s3,"s3://crabby-images/4b666/4b66611f37af6037673a4315e4b333e24b156f0b" alt=""
配置成功后,我们可以给程序设置断点、添加监视等。
data:image/s3,"s3://crabby-images/d7a62/d7a624ca6347b666841c92d18f7721bb8381b7ff" alt=""
最终程序会调出本地默认的浏览器程序并导航到http://localhost:5000
,效果如下:
data:image/s3,"s3://crabby-images/8384d/8384deb1d4f4f020bb2e0986bba9b9eaed41e9ae" alt=""
基于Kestrel本地运行应用
本示例采用Kestrel作为Web服务器,可以在project.json里看到它被作为一个依赖项。
data:image/s3,"s3://crabby-images/9b899/9b899586fe890a70ad0b5b6a52e48e2d728d46d7" alt=""
KestrelHttpServer服务器是微软推出的唯一一款基于跨平台网络库libuv的跨平台Web服务器。
通过代码可以发现通过调用IWebHostBuilder的UseKestrel扩展方法即可完成对KestrelHttpServer的注册。
namespace Microsoft.AspNetCore.Hosting
{
public static class WebHostBuilderKestrelExtensions
{
public static IWebHostBuilder UseKestrel(this IWebHostBuilder hostBuilder)
{
return hostBuilder.ConfigureServices(services =>
{
services.AddTransient<IConfigureOptions<KestrelServerOptions>, KestrelServerOptionsSetup>();
services.AddSingleton<IServer, KestrelServer>();
});
}
public static IWebHostBuilder UseKestrel(this IWebHostBuilder hostBuilder,
Action<KestrelServerOptions> options)
{
return hostBuilder.UseKestrel().ConfigureServices(services =>
{
services.Configure(options);
});
}
}
}
参考资源
- Building Projects with Yeoman
- generator-aspnet
- Your First ASP.NET Core Application on a Mac Using Visual Studio Code