검색결과 리스트
-- C#에 해당되는 글 19건
- 2012.07.18 How to Initialize Hosted WCF Services
글
Using global.asax
The global.asax file is also known as the ASP.NET “HTTP” application file. It is an optional file and if there is one, it needs to be in the root of an ASP.NET application. It contains code to handle application-level events raised by ASP.NET or HttpModules. It is tightly coupled with the ASP.NET HTTP pipeline.
Most common events that are handled in global.asax are Application_Start, Application_Init, and Application_BeginRequest, etc. Here is a simple example global.asax:
<%@Application=""Language="C#"Debug="true"%>
<scriptrunat="server">
void Application_Start(object sender, EventArgs e)
{
System.Diagnostics.EventLog.WriteEntry("ASP.NET 2.0.50727.0",
"Test Application_Start", EventLogEntryType.Information);
}
</script>
In this example, the method Application_Start is called when the application is first started. To be more precisely, it is called when the HttpApplication type is instantiated. This happens when the first HTTP request comes into the application. Under the hook, the ASP.NET system compiles global.asax into a derived type of System.Web.HttpApplication and the corresponding global methods are mapped to the events exposed from HttpApplication.
Using AppInitialize
The above global.asax does not work for non-HTTP protocols such as net.tcp and net.pipe that is supported by the Windows Activation Service (WAS) on Windows Vista. There is no protocol-agnostic counterpart for HttpApplication in this case.
Fortunately, ASP.NET provides a simple hook that works in a protocol agnostic way. The hook is based on the following AppInitialize method:
publicstaticvoid AppInitialize();
This method can be put in any type that is defined in a C# file in the application’s \App_Code directory. When the AppDomain is started, ASP.NET checks whether there is a type that has such as method (exact name and signature) and invokes it. Note that the AppInitialize method can be only defined once and it has to be in a code file instead of a pre-compiled assembly.
WCF ServiceHost Events
The type ServiceHostBase is a special CommunicationObject and thus it also exposes a list of state transitioning events such as “Opening”, “Opened”, “Closing”, “Closed”, and “Faulted”. It also exposes the event “UnknownMessageReceived”.
In self-hosted case, it is easy to understand how to hook up with these events in the application. For web hosted case, the ServiceHost is created internally by the WCF WebHost layer. However, there are still two ways to achieve this. One way is to use a custom ServiceHostFactory. Another way will be described in the next section.
The interface IServiceHostFactory is provided to support custom ServiceHost activation. In order to hook up the events for ServiceHost, we can implement this interface and put the type as the “Factory” attribute in the .svc file as following:
<%@ServiceHostLanguage="C#"Factory="HelloWorld.HelloServiceHostFactory" %>
Then in the CreateServiceHost method, we can do all of the interesting things as we can do in self-hosted case:
publicServiceHostBase CreateServiceHost(string service, Uri[] baseAddresses)
{
// The service parameter is ignored here because we know our service.
ServiceHost serviceHost = newServiceHost(typeof(HelloService),
baseAddresses);
serviceHost.Opening += newEventHandler(serviceHost_Opening);
serviceHost.Opened += newEventHandler(serviceHost_Opened);
serviceHost.Closing += newEventHandler(serviceHost_Closing);
serviceHost.Closed += newEventHandler(serviceHost_Closed);
serviceHost.Faulted += newEventHandler(serviceHost_Faulted);
serviceHost.UnknownMessageReceived += newEventHandler<UnknownMessageReceivedEventArgs>(serviceHost_UnknownMessageReceived);
return serviceHost;
}
Using ServiceHostBase.InitializeRuntime
Besides the initialization logic with IServiceHostFactory as above, you can also perform service initialization by providing your own custom ServiceHost type. By deriving from ServiceHost type, you can implement the protected method ServiceHostBase.InitializeRuntime as following:
protectedoverridevoid InitializeRuntime()
{
VirtualPathExtension extension = this.Extensions.Find<VirtualPathExtension>();
EventLog.WriteEntry("ASP.NET 2.0.50727.0",
"Service virtual path: " + extension.VirtualPath,
EventLogEntryType.Information);
base.InitializeRuntime();
}
출처 : http://blogs.msdn.com/b/wenlong/archive/2006/01/11/511514.aspx
'-- C#' 카테고리의 다른 글
Text파일의 내용을 한줄씩 읽기 (0) | 2012.09.06 |
---|---|
Excel파일 읽기 (0) | 2012.09.06 |
WCF Restful WebService (0) | 2012.06.21 |
Checked, Unchecked (0) | 2011.07.11 |
Partial class (0) | 2011.07.08 |
RECENT COMMENT