数時間頭を包み込もうとしていて、あきらめそうになりました。
私は検索(グーグルとSOの両方)を試みましたが、誰もこの問題を抱えていないようです(そしてそれについて投稿しました)。
私の問題は次のとおり
です。単純なASP.NET5 MVC6アプリケーションがあります。現在、それはまったく何もしません(コードに関して)。
以前はいくつか問題がありましたが、なんとか歯を食いしばって解決しました。
この問題はしばらくの間続くことにしました。
アプリケーションを起動すると(デバッグまたは"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
メソッド。
2番目のもの(Configure(IApplicationBuilder app)
)を削除すると、すべてが機能するはずです。のオーバーロードはサポートしていませんConfigure
。スタートアップクラスは、パブリックConfigure
メソッドを1つだけ持つことができます。
前の答え:
frameworks
セクションに追加します。を使用しているので、CoreCLR用のMongoドライバーがないために必要なだけです。project.json
mongocsharpdriver
aspnet50
System.Net.Http
ます。あなたのコードがそれを必要としているようには見えません。上記の2つで問題が解決しない場合は、使用しているKLRバージョンを教えてください。
この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。
侵害の場合は、連絡してください[email protected]
コメントを追加