簡體   English   中英

啟動ASP.NET 5(MVC 6)Web應用程序時出現AmbiguousMatchException

[英]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方法。


先前的答案:

  1. 在這里一樣project.jsonframeworks部分中至少添加一個框架。 由於您正在使用mongocsharpdriver ,因此只需要aspnet50因為沒有用於CoreCLR的Mongo驅動程序。
  2. 刪除System.Net.Http 看起來您的代碼似乎不需要它。

如果以上兩點都不能解決問題,請告訴我們您使用的KLR版本。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM