Overview
These instructions provide easy to follow steps to create a simple BizTalk integration acting as a proxy to a backend REST API.Instructions
Create a new project.
data:image/s3,"s3://crabby-images/82a54/82a54febd1dc9b33aee550bcc012de2bd4bbe5f4" alt=""
Add new property schema item to the project.
data:image/s3,"s3://crabby-images/a7fbf/a7fbf7ae0cdf72e6359fe1981dfbea943331504e" alt=""
data:image/s3,"s3://crabby-images/4efb9/4efb97556c9e981098c23086f0dc5688300f1ead" alt=""
Rename 'Property1' to 'search_term' in the 'PropertySchema1.xsd'.
data:image/s3,"s3://crabby-images/b60cc/b60cc6b75005350b36743287a55616f0ff5007b6" alt=""
data:image/s3,"s3://crabby-images/f58ba/f58baacb1b08788996732a137357dc5980833a6e" alt=""
At this point it's probably a good idea to give the application name and set signing.
Go to the project properties.
data:image/s3,"s3://crabby-images/13f8b/13f8b96c3b89dc5f96186b94f8d84c187f6f2fe1" alt=""
Go to Deployment -> set Application Name value
data:image/s3,"s3://crabby-images/4e716/4e71625c3a2c2f62e6c2f9712bb0f417600b7f74" alt=""
Go to Signing and in the key file selection select <New...>
data:image/s3,"s3://crabby-images/07e06/07e06fa69c1516fef4e4f08755d735c55cc92cff" alt=""
Give a name for the key
data:image/s3,"s3://crabby-images/60588/605881d3803dee5fa34b494a0e6e618ddcd43e1e" alt=""
data:image/s3,"s3://crabby-images/dff81/dff819d6e98e18b5a9e3a127f85cc15d90ea630c" alt=""
Build the solution.
data:image/s3,"s3://crabby-images/3697f/3697fffac4b6b80944ba25c9545430f9a29e373f" alt=""
data:image/s3,"s3://crabby-images/437c1/437c1417a93d9e82c02c08ddb9a3952e26621e6e" alt=""
Deploy the integration to BizTalk.
data:image/s3,"s3://crabby-images/33de2/33de24939225ba4142adfb586600a74a23ae9ee8" alt=""
data:image/s3,"s3://crabby-images/57440/574406fe8f7b553e49803e4b6695ab459913a4b2" alt=""
Go to the BizTalk Server Administrator Console. Your newly deployed integration should be there.
data:image/s3,"s3://crabby-images/ac8a6/ac8a626ac5a5a0f82f54c9c34a23638abc7263b6" alt=""
Next we'll create receive location and receive port.
Go back to the Visual Studio and go to Tools -> BizTalk WCF Service Publishing Wizard.
data:image/s3,"s3://crabby-images/b7585/b7585d7c062e02a5789415f4405aeee79f271f4a" alt=""
data:image/s3,"s3://crabby-images/0d8bc/0d8bc43cf2fa509f461edb172b2dc1dfa60295ff" alt=""
Select WCF-WebHttp and DeploymentFrameworkTest application.
data:image/s3,"s3://crabby-images/c4c65/c4c6517ea79ed98430227ff7004d20f0a3b70ee8" alt=""
data:image/s3,"s3://crabby-images/63b4d/63b4d3c863353523122d02cc6855802c7dd1f4ca" alt=""
Request-Response Receive Port is needed for our proxy integration because it needs talk back to the caller.
data:image/s3,"s3://crabby-images/08dc5/08dc5a9518654208d9027fe021926ca9b1269c27" alt=""
Give a name for the IIS app. Allow anonymous access. You can change this later in IIS if needed.
data:image/s3,"s3://crabby-images/ffab8/ffab860c4d1c2fb4a374e60bc9ed76f33c074e8b" alt=""
Create.
data:image/s3,"s3://crabby-images/c19b6/c19b6eae6b87785365b225c12903c636c0417a77" alt=""
Fi
data:image/s3,"s3://crabby-images/ffebe/ffebe537b69c4859f2c390de1fac39cf6f252b0e" alt=""
Go to IIS Manager, you'll see the app was created.
data:image/s3,"s3://crabby-images/70456/704567f54f6aa6a1a1531a64547462cf4505e6f9" alt=""
Go to the BizTalk Server Admin Console.
A receive location and a receive port were created.
data:image/s3,"s3://crabby-images/0498f/0498fa2383ec223f7cfde1aa6a93679c65a473a6" alt=""
data:image/s3,"s3://crabby-images/e3dfe/e3dfe78b0f4bc740e6383c0d2e1b70f0662caefd" alt=""
Go to the receive location -> Configure.
BizTalkServerIsolatedHost as receive handler basically means this happens outside the BizTalk, namely IIS in this case. Because we creating a proxy that does not in any way do modifications to the data, pipelines are both PassThru.
data:image/s3,"s3://crabby-images/06975/06975129c5f5d8427bb0a86c64ddf193fd44559c" alt=""
To the HTTP Method and URL Mapping insert the following code:
<BtsHttpUrlMapping>
<Operation Method="GET" Url="/{search_term}"/>
</BtsHttpUrlMapping>
Then click 'Edit'.
data:image/s3,"s3://crabby-images/3764d/3764db1ab65f14b4b1c8e77d82331e7196179c4c" alt=""
The value for the property namespace can be fetched from the Visual Studio project.
data:image/s3,"s3://crabby-images/b69ef/b69efcea9cf8c3ad70027cdf9426e6885b90becc" alt=""
data:image/s3,"s3://crabby-images/ea7be/ea7be1e96f0dbe4f3391b7c3b3e3e81a4c4cadc3" alt=""
On the messages tab add 'GET'.
OK
data:image/s3,"s3://crabby-images/70d1f/70d1f24a487fe1bd89cb2d8b105f0c3af0036e9c" alt=""
OK
data:image/s3,"s3://crabby-images/ca9f2/ca9f27056f1c145324c4cfb681daa3affe2971aa" alt=""
Go to the send ports and create a new port.
data:image/s3,"s3://crabby-images/5f62e/5f62ed086cee5d53b9eea25bd4c1c86b8f993df9" alt=""
Set whatever name you want and click Configure.
data:image/s3,"s3://crabby-images/d2eb4/d2eb483d92abdbd6cd6050b3785bef87b6a2d248" alt=""
Set the URI. In the mapping insert the following (replace [your profile] and [your own API key] with you own values you have got from the service):
<BtsHttpUrlMapping>
<Operation Method="GET" Url="/basic?search_word={search_term}&profile=[your profile]&key=[your own API key]&country=se&version=1.1.3"/>
</BtsHttpUrlMapping>
data:image/s3,"s3://crabby-images/45f14/45f14b241db8a8fc9945dc030efcfcf3ce6c214b" alt=""
The mapping values are the same as in the receive location.
data:image/s3,"s3://crabby-images/89ee0/89ee0735be9f92e0d7fa706135434543d808ab7c" alt=""
OK
data:image/s3,"s3://crabby-images/fbc77/fbc77dadb3237c4d143504062bd33d4349d0739c" alt=""
In Filters set property BTS.ReceivePortName == WcfService_DeploymentFrameworkTest/Service1
OK
data:image/s3,"s3://crabby-images/438c4/438c4951c98a3cdad3a4fab8b4b83aa572dafd87" alt=""
Set retry count to 0
data:image/s3,"s3://crabby-images/82531/82531295ee60938ced5d090e06f20ea2bfc2bb37" alt=""
OK
data:image/s3,"s3://crabby-images/bc13b/bc13bc680b6d345ce01b674d50a157632cbcd5a0" alt=""
Start the application
data:image/s3,"s3://crabby-images/b6b9c/b6b9c1fc2645061db935d6cb33156bf6561c11a8" alt=""
data:image/s3,"s3://crabby-images/395e4/395e40809d1e112d0bc762bd21a1dcae60a51843" alt=""
If you want to see possible error messages edit the "C:\inetpub\wwwroot\DeploymentFrameworkTest\Web.config".
Set includeExceptionDetailInFaults="true", httpGetEnabled="true", httpsGetEnabled="true" and save the file.
data:image/s3,"s3://crabby-images/b91cf/b91cfd562d7d881fa9a61cb554aa07c39d894c64" alt=""
Now you can call the integration that proxies the request to the backend REST API and returns the response.
data:image/s3,"s3://crabby-images/51d2c/51d2cf63bebbb5b1fc6d4b09117c2c55081c1ec5" alt=""
No comments:
Post a Comment