只是为了好玩,今天早些时候,我的一位同事问我是否可以尝试使用ASP.NET Core来创建一个微小的WebAPI来回应请求。 我能够在大约70行代码中完成WebAPI。所有这一切都归功于ASP.NET Core令人惊叹!所以,这就是我到目前为止所做的。
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Http;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Newtonsoft.Json;
using System;
using System.Linq;
namespace TinyWebApi
{
class Program
{
static readonly IWebHost _host;
static readonly string[] _urls = { "http://localhost:80" };
static Program()
{
IConfiguration _configuration = new ConfigurationBuilder()
.AddJsonFile("appsettings.json", optional: true, reloadOnChange: true)
.Build();
_host = BuildHost(new WebHostBuilder(), _configuration, _urls);
}
static void Main(string[] args)
{
_host.Run();
}
static IWebHost BuildHost(
IWebHostBuilder builder, IConfiguration configuration, params string[] urls)
{
return builder
.UseKestrel(options =>
{
options.NoDelay = true;
})
.UseConfiguration(configuration)
.UseUrls(urls)
.Configure(app =>
{
app.Map("/echo", EchoHandler);
})
.Build();
}
static void EchoHandler(IApplicationBuilder app)
{
app.Run(async context =>
{
await context.Response.WriteAsync(
JsonConvert.SerializeObject(new
{
StatusCode = (string)context.Response.StatusCode.ToString(),
PathBase = (string)context.Request.PathBase.Value.Trim('/'),
Path = (string)context.Request.Path.Value.Trim('/'),
Method = (string)context.Request.Method,
Scheme = (string)context.Request.Scheme,
ContentType = (string)context.Request.ContentType,
ContentLength = (long?)context.Request.ContentLength,
QueryString = (string)context.Request.QueryString.ToString(),
Query = context.Request.Query
.ToDictionary(
_ => _.Key,
_ => _.Value,
StringComparer.OrdinalIgnoreCase)
})
);
});
}
}
}
(上面的代码按预期工作,并没有被破坏。)
WebAPI应该用JSON回显请求。
示例请求
http://localhost/echo?q=foo&q=bar
示例回复
{
"StatusCode": "200",
"PathBase": "echo",
"Path": "",
"Method": "GET",
"Scheme": "http",
"ContentType": null,
"ContentLength": null,
"QueryString": "?q=foo&q=bar",
"Query": {
"q": [
"foo",
"bar"
]
}
}
我只用70多行代码就把我的同事吹走了,但是当我们查看文件大小时,它并不令人印象深刻......
目前所有这些依赖项,我的WebAPI正在编译为 54.3MB。
我一直在试图弄清楚如何减少这个项目的磁盘空间。我安装的软件包捆绑了很多我们真正不需要的东西,而且我一直在努力找到最好的资源或方法去除这个项目不需要的参考资料。
.csproj
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<OutputType>Exe</OutputType>
<TargetFramework>netcoreapp1.1</TargetFramework>
<RuntimeIdentifier>win7-x64</RuntimeIdentifier>
<ApplicationIcon>Icon.ico</ApplicationIcon>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="Microsoft.AspNetCore" Version="1.1.2" />
<PackageReference Include="Microsoft.AspNetCore.Hosting.Abstractions" Version="1.1.2" />
<PackageReference Include="Microsoft.AspNetCore.Mvc.Core" Version="1.1.3" />
<PackageReference Include="Microsoft.AspNetCore.Server.Kestrel" Version="1.1.2" />
<PackageReference Include="Microsoft.Extensions.Configuration.FileExtensions" Version="1.1.2" />
<PackageReference Include="Microsoft.Extensions.Configuration.Json" Version="1.1.2" />
<PackageReference Include="Microsoft.Extensions.Logging.Console" Version="1.1.2" />
<PackageReference Include="Newtonsoft.Json" Version="10.0.2" />
</ItemGroup>
</Project>
根据提供的代码,有什么方法让我知道我的项目需要什么参考?我之前开始擦除清除所有上述依赖项,然后尝试逐个添加它们,但事实证明,这是一个永无止境的尝试解决缺失的参考文献的头痛,似乎需要永远解决。我确定那里的某个人有这样的解决方案,但我似乎无法找到它。感谢。
答案 0 :(得分:5)
我所做的只是将代码复制到新的.NET Core控制台项目并解决了缺少的引用。为了找出你需要为缺少的API添加哪些,我只是对缺少的成员(转到定义)在工作项目中做了F12,所有引用都参见了定义API的程序集。
由于您没有在此使用任何内容,因此VS中提供的ASP.NET Core Web application
模板已经使用了所有这些API,因此您可以将其用作“工作项目”。
AddJsonFile
例如在Microsoft.Extensions.Configuration.Json
包中定义。
所以最后我留下了
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<OutputType>Exe</OutputType>
<TargetFramework>netcoreapp1.1</TargetFramework>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="Microsoft.AspNetCore.Server.Kestrel" Version="1.1.2" />
<PackageReference Include="Microsoft.Extensions.Configuration.Json" Version="1.1.2" />
<PackageReference Include="Newtonsoft.Json" Version="10.0.2" />
</ItemGroup>
</Project>
发布时最多可增加2.41MB。
当然,您可能不希望在更大的项目上执行此操作。 在这个项目上只需要一分钟左右。