4

http://www.servicestack.net/ServiceStack.Hello/のサービススタック「HelloWorld」チュートリアルに従っています。しかし、asp.netアプリケーションを起動しようとすると、「値をnullにすることはできません。パラメーター名:EndpointHost.Config」と表示されます。

完全な例外テキストは次のとおりです。

[ArgumentNullException: Der Wert darf nicht NULL sein.
Parametername: EndpointHost.Config]

[ConfigurationErrorsException: ServiceStack: AppHost does not exist or has not been initialized. Make sure you have created an AppHost and started it with 'new AppHost().Init();' in your Global.asax Application_Start()]
   ServiceStack.WebHost.Endpoints.ServiceStackHttpHandlerFactory..cctor() in C:\src\ServiceStack\src\ServiceStack\WebHost.EndPoints\ServiceStackHttpHandlerFactory.cs:45

[TypeInitializationException: Der Typeninitialisierer für "ServiceStack.WebHost.Endpoints.ServiceStackHttpHandlerFactory" hat eine Ausnahme verursacht.]

[TargetInvocationException: Ein Aufrufziel hat einen Ausnahmefehler verursacht.]
   System.RuntimeTypeHandle.CreateInstance(RuntimeType type, Boolean publicOnly, Boolean noCheck, Boolean& canBeCached, RuntimeMethodHandle& ctor, Boolean& bNeedSecurityCheck) +0
   System.RuntimeType.CreateInstanceSlow(Boolean publicOnly, Boolean fillCache) +86
   System.RuntimeType.CreateInstanceImpl(Boolean publicOnly, Boolean skipVisibilityChecks, Boolean fillCache) +230
   System.Activator.CreateInstance(Type type, Boolean nonPublic) +67
   System.RuntimeType.CreateInstanceImpl(BindingFlags bindingAttr, Binder binder, Object[] args, CultureInfo culture, Object[] activationAttributes) +1051
   System.Activator.CreateInstance(Type type, BindingFlags bindingAttr, Binder binder, Object[] args, CultureInfo culture, Object[] activationAttributes) +111
   System.Web.Configuration.HttpHandlerAction.Create() +57
   System.Web.Configuration.HandlerFactoryCache..ctor(HttpHandlerAction mapping) +19
   System.Web.HttpApplication.GetFactory(HttpHandlerAction mapping) +96
   System.Web.HttpApplication.MapHttpHandler(HttpContext context, String requestType, VirtualPath path, String pathTranslated, Boolean useAppConfig) +125
   System.Web.MapHandlerExecutionStep.System.Web.HttpApplication.IExecutionStep.Execute() +93
   System.Web.HttpApplication.ExecuteStep(IExecutionStep step, Boolean& completedSynchronously) +155

私のグローバルクラスは次のとおりです。

public class Global : System.Web.HttpApplication
    {
        /// Web Service Singleton AppHost
        public class InfoAppHost : AppHostBase
        {
            //Tell Service Stack the name of your application and where to find your web services
            public InfoAppHost()
                : base("Services", typeof(InfoService).Assembly) { }

            public override void Configure(Funq.Container container) { }
        }

        protected void Application_Start(object sender, EventArgs e)
        {
            //Initialize your application
            var appHost = new InfoAppHost();
            appHost.Init();
        }
    }

しかし、それは決して呼ばれないようです。ホームページからサンプルプロジェクトをコンパイルすることは問題なく機能しますが、ホームページからの例に従いたいと思います。この問題を解決する方法はありますか?

4

5 に答える 5

2

テストプロジェクトを削除して、チュートリアルをもう一度試しました。

Global.asaxファイルを作成するときに、クラス全体を削除し、このファイルで別のクラスをGlobalにしました。このクラスではApplication_Startが呼び出されなかったようです。

于 2011-09-22T10:20:24.490 に答える
1

ご想像のとおり、問題はappHost.Init()が実行されていないことです。try / catchでラップし、スローされた可能性のあるエラーをログに記録してみてください。

于 2011-09-24T05:53:07.043 に答える
1

同じ問題が発生し、拡張されたApplicationPool設定で「Activate32-bit-applications」をtrueに設定することで解決しました。(申し訳ありませんが、ドイツ語のWindowsしかないため、設定名は大まかな推測です)

于 2013-12-18T12:19:03.597 に答える
0

この問題を引き起こすために私が間違っていたことを理解するのにしばらく時間がかかりました...

これは、Global.asaxファイルをプロジェクトのサブフォルダーに誤ってドラッグしたために発生しました。

于 2013-04-04T17:49:28.480 に答える
0

このエラーはWebApiConfigが原因であることがわかりました。この例ではServiceStackを使用しており、ASP.NETWebAPIは必要ありません。その行は、Gloabal.asax.csファイルでコメントアウトする必要があります。

    protected void Application_Start()
    {
        AreaRegistration.RegisterAllAreas();

        // ** comment out ** WebApiConfig.Register(GlobalConfiguration.Configuration);
        FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
        RouteConfig.RegisterRoutes(RouteTable.Routes);
        BundleConfig.RegisterBundles(BundleTable.Bundles);

        new ProteinTrackerAppHost().Init();
    }
于 2013-10-04T03:11:23.323 に答える