One day I just felt the need to create a Secured ColdFusion Web Service and to my wonder I just found good examples of consuming it but none for publishing it. That influenced me to write a blog for Web Service published in ColdFusion, consumed in ColdFusion and that too in a secured manner using <cfinvoke>/<cfobject> username/password feature.
Without giving the overview I will just get into the details but before that it's must to understand that how is ColdFusion behaving from client side . From client side when you give username/password in <cfinvoke> tag or <cfobject> tag (see the sample code below), then ColdFusion sends the information as part of the request. The login information is passed to web server using HTTP basic authentication.
Without giving the overview I will just get into the details but before that it's must to understand that how is ColdFusion behaving from client side . From client side when you give username/password in <cfinvoke> tag or <cfobject> tag (see the sample code below), then ColdFusion sends the information as part of the request. The login information is passed to web server using HTTP basic authentication.
Please note that these are just code snippets. I will share the complete code in the end.
You just saw how easy it is to consume a web service in ColdFusion. Publishing also is a very simple task but there is a twist. ColdFusion doesn't give any specific feature to handle the authentication (username/password) sent by client-side(using cfinvoke/cfobject). But that doesn't mean you can not handle it. ColdFusion has already given an awesome feature of <cflogin> and expects the user to authenticate the credentials using that same feature.
Here is snippet of <cflogin> authentication.
Please read the comments inline to understand the code.
We just saw how to catch the username and password sent in request by cfinvoke but the question is where to use it. I will suggest to use this code in Application.cfc instead of web service component. The reason is, it could save you a lot of code rewriting and easy to maintain. You can just write the code once in Application.cfc in onRequestStart() method and for every request it will ask for authorization otherwise will send UnAuthorized status.
I hope you got an idea of how to consume a web-service with credentials and how to publish a web-service which gives on access on proper authorization.
So now I will post the complete code for doing this. There will be three files namely: securedws.cfm, securedws.cfc and Application.cfc. I am assuming that ColdFusion9(installed in C:\) is used and these files are kept under C:/coldfusion9/wwwroot/securedwebservices/
Please change the URL of webservices in code given below accordingly if your configuration is different.
Please note that for consuming the web-services always prefer <cfinvoke> tag over <cfobject>. cfobject tag has one limitation, it caches the first username/password and then even if you will change the credentials, it will send the first credentials only.
For example, consider that there are two users for your webservice with two credentials lets say: user1/pass1 and user2/pass2.
First lets use cfobject with credentials of first user(user1/pass1) and try to access the web-service. It will send the correct credentials to web-service. Now change the credentials in the same cfobject and use second user's one(user2/pass2) and access the webservice. This time request should have send second user's credentials(user2/pass2) but it actually passes (user1/pass1). You can confirm this behavior using <cfdump output="console" var="#cflogin#"> at server side.
This behavior is only observed with cfobject only and is quite dangerous. So I will suggest you to use cfinvoke.
Feel free to post any queries.
ColdFusion Rocks!!!
Hello Milan
ReplyDeleteI have been searching for answers to a problem and hoping you can help. In CF9, I have been successfully consuming a webservice. In CF10, the same code is failing with the error message "Unable to parse WSDL as an XML document." I have simplified the code to the point where I am just trying to ping the webservice with their Ping method. Essentially my one line of code looks like:
As I mentioned, this works fine in CF9, but fails in CF10. I have tried adding wsversion="1" and wsversion="2", but neither helped resolved the problem.
Any help would be greatly appreaciated!!
Thank you
Virginia Neal
The article is very Impressive. every concept of this article very clearly explained and easily clarify the queries for the Beginners.
ReplyDeleteData Science Training Course In Chennai | Data Science Training Course In Anna Nagar | Data Science Training Course In OMR | Data Science Training Course In Porur | Data Science Training Course In Tambaram | Data Science Training Course In Velachery
I like viewing web sites which comprehend the price of delivering the excellent useful resource free of charge. I truly adored reading your posting. Thank you!
ReplyDeletesalesforce training in chennai
software testing training in chennai
robotic process automation rpa training in chennai
blockchain training in chennai
devops training in chennai
An effective setup could be venues providing testing infrastructure and sending data to the event app. thank you note for birthday party attendance and thank you letter after presentation
ReplyDeleteSomeone Sometimes with visits your blog regularly and recommended it in my experience to read as well. The way of writing is excellent and also the content is top-notch. Thanks for that insight you provide the readers! Frontend developer
ReplyDelete