[英]AmbiguousMatchException when starting ASP.NET 5 (MVC 6) Web Application
幾個小時以來,我一直在努力將自己的頭纏住,直到幾乎要放棄。
我曾嘗試搜索(谷歌和谷歌搜索引擎搜索),但似乎沒有人遇到這個問題(並發布了它)。
我的問題如下:
我有一個簡單的ASP.NET 5 MVC 6應用程序; 目前,它絕對不執行任何操作(按代碼進行)。
之前我遇到了幾個問題,但設法解決了這個問題。
這個問題決定堅持一段時間。
啟動應用程序(通過調試或使用"k web"
/ "k kestrel"
命令),出現以下異常:
System.Reflection.AmbiguousMatchException: Ambiguous match found.
at System.RuntimeType.GetMethodImpl(String name, BindingFlags bindingAttr, Binder binder, CallingConventions callConv, Type[] types, ParameterModifier[] modifiers)
at System.Type.GetMethod(String name, BindingFlags bindingAttr)
at System.Reflection.TypeInfo.GetDeclaredMethod(String name)
at Microsoft.AspNet.Hosting.Startup.StartupLoader.FindMethod(Type startupType, String methodName, String environmentName, Type returnType, Boolean required)
at Microsoft.AspNet.Hosting.Startup.StartupLoader.LoadStartup(String applicationName, String environmentName, IList`1 diagnosticMessages)
at Microsoft.AspNet.Hosting.Startup.StartupManager.LoadStartup(String applicationName, String environmentName)
at Microsoft.AspNet.Hosting.HostingEngine.EnsureApplicationStartup(HostingContext context)
at Microsoft.AspNet.Hosting.HostingEngine.EnsureApplicationDelegate(HostingContext context)
at Microsoft.AspNet.Hosting.HostingEngine.Start(HostingContext context)
at Microsoft.AspNet.Hosting.Program.Main(String[] args)
我的config.json:
{
"webroot": "httpdocs",
"version": "1.0.0-beta3",
"exclude": [
"httpdocs"
],
"packExclude": [
"**.kproj",
"**.user",
"**.vspscc"
],
"dependencies": {
// ASP.NET:
"Microsoft.AspNet.Server.IIS": "1.0.0-beta3",
"Microsoft.AspNet.Server.WebListener": "1.0.0-beta3",
"Microsoft.AspNet.Mvc": "6.0.0-beta3",
"Microsoft.AspNet.Mvc.Razor": "6.0.0-beta3",
"Microsoft.AspNet.Diagnostics": "1.0.0-beta3",
"Microsoft.AspNet.StaticFiles": "1.0.0-beta3",
// "Microsoft.Framework"
"Microsoft.Framework.ConfigurationModel.Json": "1.0.0-beta3",
"Microsoft.Framework.DependencyInjection": "1.0.0-beta3",
"Microsoft.Framework.Logging": "1.0.0-beta3",
"Microsoft.Framework.Logging.Console": "1.0.0-beta3",
"Microsoft.VisualStudio.Web.BrowserLink.Loader": "14.0.0-beta3"
//"System.Net.Http": "4.0.0-beta-22416",
//"mongocsharpdriver": "1.10.0"
},
"commands": {
"web": "Microsoft.AspNet.Hosting --server Microsoft.AspNet.Server.WebListener --server.urls http://localhost:5001",
"kestrel": "Microsoft.AspNet.Hosting --server Kestrel --server.urls http://localhost:5002"
},
"frameworks": {
"aspnet50": { }
}
}
我的Startup.cs(基本上是示例中的標准):
using System;
using Microsoft.AspNet.Builder;
using Microsoft.AspNet.Hosting;
using Microsoft.Framework.ConfigurationModel;
using Microsoft.Framework.DependencyInjection;
using Microsoft.Framework.Logging;
using Microsoft.Framework.Logging.Console;
using Microsoft.AspNet.Diagnostics;
namespace MausSite
{
public class Startup
{
public IConfiguration Configuration { get; private set; }
public Startup(IHostingEnvironment env)
{
Configuration = new Configuration()
.AddJsonFile("config.json")
.AddEnvironmentVariables();
}
public void ConfigureServices(IServiceCollection services)
{
services.AddMvc();
}
public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerfactory)
{
loggerfactory.AddConsole();
// Add the following to the request pipeline only in development environment.
if (String.Equals(env.EnvironmentName, "development", StringComparison.OrdinalIgnoreCase))
{
app.UseBrowserLink();
app.UseErrorPage(ErrorPageOptions.ShowAll);
}
else
{
// Add Error handling middleware which catches all application specific errors and
// send the request to the following path or controller action.
app.UseErrorHandler("/Home/Error");
}
app.UseStaticFiles();
app.UseMvc(routes =>
{
routes.MapRoute(
name: "default",
template: "{controller}/{action}/{id?}",
defaults: new { controller = "Home", action = "Index" });
});
}
public void Configure(IApplicationBuilder app)
{
// For more information on how to configure your application, visit http://go.microsoft.com/fwlink/?LinkID=398940
}
}
}
我基本上已經注釋掉了所有代碼,以確保不是引起異常的原因(考慮到堆棧跟蹤,這似乎也不可能)。
有人遇到過類似問題嗎?
歡迎所有想法!
編輯:我正在使用"klr-clr-win-x86 1.0.0-beta3"
/ "klr-clr-win-x64 1.0.0-beta3"
該錯誤在兩個方面均持續存在。
也更新了我的project.json。
找到了問題。 它被隱藏在文件底部: Configure
方法。
刪除第二個( Configure(IApplicationBuilder app)
),一切正常。 我們不支持Configure
重載。 啟動類只能有一個公共的Configure
方法。
先前的答案:
project.json
的frameworks
部分中至少添加一個框架。 由於您正在使用mongocsharpdriver
,因此只需要aspnet50
因為沒有用於CoreCLR的Mongo驅動程序。 System.Net.Http
。 看起來您的代碼似乎不需要它。 如果以上兩點都不能解決問題,請告訴我們您使用的KLR版本。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.