I recently worked with a situation that required deployment of a new RESTful web service layer that worked in concert with an existing ASP.Net application. A process of refactoring required the projects to be treated separately and to be deployed on different URLs. Both URLs were owned by the same organization and browser version compatibility requirements were well defined. The browser support requirement included IE7 and newer, Firefox, Chrome and Safari.
Due to browser support issues, it was not ideal to use either CORS or JSONP to meet the requirements as both have various issues with certain browsers. After reviewing the F5 documentation a solution was created using an iRule on the switch to represent the RESTful web site as a 'virtual folder' under the main web site. This hides the real location of the REST service layer from the client and the client browser is not aware of the switch happening behind the scenes. The client sees the RESTful service site on the same URL as the ASP.net site and nothing special is needed to make ajax calls.
when HTTP_REQUEST { if { [HTTP::uri] starts_with "/restservice" } { if {([string tolower [HTTP::host]] contains "aspapp.example.com")}{ HTTP::header replace "Host" "restsvc.example.com" HTTP::uri [substr [HTTP::uri] 12 ] } } }
This iRule traps on URI's that begin with /restservice. If found it verifies that the host is the ASP.net application URL, and replaces it with the restservice URL replacing the Host from it's original URL (restsvc.example.com). The final command modifies the URI to remove the virtual folder from the call to create the new, proper URL that can be interpreted by the server.
The iRule allows pages at: aspappdomain.example.com to make ajax calls to the rest service at aspappdomain.example.com/restservice even though that URL doesn't actually exist anywhere, except in this iRule.
The key to making this work is that both sites must be serviced on the same IP address and be using host header names to serve the proper content. If the sites are on different IPs the iRule will have no effect.
These few lines of code saved a lot of work on the client side and ensured support accross all browsers quickly and easily.
No comments:
Post a Comment