Skip to main content

Hosting WCF service in an ASP.NET website

WCF services can be hosted in IIS as an ASP.NET Website. This provides a number of benefits. First of all the service process need not be running for the request to be made, instead it is started when a request is made. Further, IIS mgr can be used to manage the service. One of the main disadvantage of hosting WCF service like this is that it forces the endpoints to use HTTP.

1. Open the solution attached here.

2. Right click on the solution > select add > New Web Site... > select WCF Service template > use ProdSrvWebsiteHost as the name.

2. Expand App_code, look at IService.cs and Service.cs. Delete IService.cs and Service.cs  and open Service.svc and inspect.

3. Add reference to the ProductServiceLibrary

4. Add a ServiceHost directive with Service attribute pointing to Service.svc.

<%@ ServiceHost service="ProductServiceLibrary.ProductService" %>

5. Open web.config and notice that the base address is not specified. Base address specified in the web.config is ignored and instead IIS application's base address is used.

6. Use relative address for endpoints, if using absolute address it should match that of the base address.

    <services>
      <service name="ProductServiceLibrary.ProductService" behaviorConfiguration="MyBehaviorConfig">
        <endpoint address="" binding="basicHttpBinding" contract="ProductServiceLibrary.IProductService"/>
        <endpoint address="ws" binding="wsHttpBinding" contract="ProductServiceLibrary.IProductService"/> 
      </service>
    </services>

6. Add a name attribute to behavior as shown below

    <behaviors>
      <serviceBehaviors>
        <behavior name="MyBehaviorConfig">
          <serviceMetadata httpGetEnabled="true" httpsGetEnabled="true"/>
          <serviceDebug includeExceptionDetailInFaults="false"/>
        </behavior>
      </serviceBehaviors>

    </behaviors>


7. Right click service.svc > view in browser. Notice that an exception is thrown.

"The service cannot be activated because it does not support ASP.NET compatibility. ASP.NET compatibility is enabled for this application. Turn off ASP.NET compatibility mode in the web.config or add the AspNetCompatibilityRequirements attribute to the service type with RequirementsMode setting as 'Allowed' or 'Required'."

8. Locate aspNetCompatibilityEnabled attribute in web.config and set it to false.

aspNetCompatibilityEnabled="false"



9. Right click service.svc > view in browser. Now you should be able to access Metadata publishing for the service.

10. update the client service reference - right click on the service reference > select Configure Service Reference > paste the metadata address in the address field > Click OK

11. Check if the app config has been updated, check the endpoints and their addresses to ensure

12. Open programs.cs, update the endpoint name of the client instance to

ProductServiceClient client = new ProductServiceClient("WSHttpBinding_IProductService");

13. Test the client project. If it throws an exception, enable debug to learn more about the exception. To do this open Web.config of ProdSrvWebsiteHost, locate debug and set it to true as shown below:

<compilation debug="true/>.










Comments

Popular posts from this blog

CUMIPMT and CUMPRINC function

CUMIPMT Cumulative interest payment function allows you to calculate the interest paid for a loan or from an investment from period A to period B. When getting a loan, CUMIPMT function can be used to calculate the total amount of interest paid in the first five months or from period 12 to period 20. A period can be a month, a week or two week. Loan Amount : 350,000.00 APR: 4.5% Down payment: 0.00 Years: 25 Payment per year: 12 From the above data, we can calculate the following: No of Period: 25 × 12 = 300 Periodic Rate: 4.5/12 = 0.375% Here is how you will substitute these values into the function. = CUMIPMT (periodic rate, No of period, vehicle price, start period, end period,  ) = CUMIPMT (0.375, 300, 350000, 1, 5, 0) In an excel worksheet, we use cell address instead of actual values as shown below: Here is the formula view of the worksheet: CUMPRINC Another related function is CUMPRINC. CUMPRINC function is used to calculate cumul

Excel PMT Function

PMT function is very useful for calculating monthly payment required to payback a loan or mortgage at a fixed rate. This function require a minimum of three inputs, periodic rate, number of periods, present value or the loan amount. Here is a simple example. Home Loan: 350,000.00 Interest rate: 4.5% Number of years to repay the loan: 25 Note: To calculate monthly payment, we need to find the monthly rate and number of months as shown above. Then it is simply a matter of substituting the values into the payment function, as shown in the formula view below.

BCG's Brand Advocacy Index

The Boston Consulting Group's (BCG) Brand Advocacy Index (BAI) is a metric developed to help companies measure the degree of customer advocacy for their brands. BAI focuses on the likelihood of customers to recommend a brand to others, which is a powerful indicator of brand strength and customer loyalty. Unlike other customer satisfaction or loyalty metrics, BAI emphasizes the importance of customer referrals and word-of-mouth marketing. BAI is calculated based on a survey where customers are asked about their willingness to recommend a brand to their friends, family, or colleagues. The responses are then used to compute a score, which ranges from -100 to 100. A higher BAI score indicates that a brand has more advocates who are likely to recommend the brand to others, while a lower score suggests that the brand has fewer advocates or even a higher number of detractors. BCG's research has shown that companies with higher BAI scores tend to experience higher growth rates and bett