0

私は、Web サービスの大規模なセットを AJAX 呼び出しで利用できるようにしています。[System.Web.Script.Services.ScriptService]を各サービスに追加しました。IHttpModule.Init オーバーライドで、ロギングと国際化のために定期的に使用するいくつかのオブジェクトを初期化する、登録済みの HttpModule があります。IHttpModule.Init は、任意の Web メソッドに対して SOAP 要求を行うときに呼び出されますが、任意の Web メソッドに対して JSON 要求を行うときには呼び出されないようです。呼び出されたときにファイルに書き込むことで、これを確認しました。

.Net Web サービスが JavaScript プロキシ (AJAX) を介して呼び出される場合、HttpModules は使用されますか? もしそうなら、私はある種の構成を欠いていますか? 以下に含まれる関連コードビット。

-コリン-


Web.config:

<httpModules><add name="GlobalApplicationModule" type="Common.GlobalApplicationModule, Common"/></httpModules>

HTTPModules.cs:

class GlobalApplicationModule : IHttpModule
{
  public void Dispose()
  {
      Internationalization.LanguageProvider.ReleaseAllResources();
  }

  public void Init(HttpApplication application)
  {
    // DEBUG: Confirm that this method is called
    StreamWriter writer = new StreamWriter("c:\\deleteme-HTTP_module_test.txt");
    writer.WriteLine("Init called.");
    writer.Close();

    // Initialize logger
    Common.Logger.Initialize("LogAssemblyPath", "LogClassName");

    Common.CentralConfiguration.CreateConfiguration(new  Common.CentralizedStrategy());

    // Initialize language provider
    if (!Internationalization.LanguageProvider.Initialized)
    {
      try 
      {
        string debug = System.Configuration.ConfigurationManager.AppSettings["debugInternationalization"];
        string languageAssemblyLocation = System.Configuration.ConfigurationManager.AppSettings["LanguageAssemblyLocation"];
        string languageAssemblyBaseName = System.Configuration.ConfigurationManager.AppSettings["LanguageAssemblyBaseName"];
        languageAssemblyLocation = System.Web.HttpContext.Current.Server.MapPath(languageAssemblyLocation);
        Internationalization.LanguageProvider.Init(languageAssemblyLocation, languageAssemblyBaseName, false);
        if (debug != null && bool.Parse(debug))
        {
          Internationalization.LanguageProvider.PrefixText = "*";
        }
      }
      catch (Exception x)
      {
        Common.Logger.Instance.LogError("Could not intialize assembly language provider.  Error: " + x.Message);
      }
    }
  }
}
4

1 に答える 1

0

これは非常に奇妙なデバッグ ログの方法です... 問題の原因は、IIS の構成にある可能性が最も高いです。IIS が ASP.NET に要求をまったく渡していないようです。マッピングを確認してください。

于 2010-03-16T21:35:39.443 に答える