OK. But why on earth you would like to use PL/SQL to perform a HTTP POST request!? Turns out, there still are a lot of software shops or businesses with a software department with extremely highly skilled Oracle developers, that need to focus on solving complex business issues with a database instead of learning the new cool programming language that you can use to do this exact same task with two lines of code. For them, a PL/SQL wrapper around a RESTful API is pretty convenient.
So, here's what I did to perform a POST passing two parameters along:
create or replace package wsaccess_pkg as /* suppose your RESTful API requires a POST with two parameters: id, name and it returns a string containing an xml */ -- id number -- name string function executews ( p_id number, p_name varchar2 ) return varchar2; end wsaccess_pkg; create or replace package body wsaccess_pkg as function executews ( p_id number, p_name varchar2 ) return varchar2 AS postData clob; xmlData clob; v_url varchar2(500); v_msg varchar(512); req utl_http.req; resp utl_http.resp; begin utl_http.set_response_error_check(enable => TRUE); -- this is your RESTful API's URL where you would POST data v_url := 'http://www.example.com/api/scoreCard'; postData := ''; postData := postData || 'id=' || p_id || '&'; postData := postData || 'name=' || p_name || '&'; -- begin request stating that method will be POST req := utl_http.begin_request(url => v_url, method => 'POST'); -- setup request's headers. you need both: Content-Type and Content-Length utl_http.set_header(req, 'Content-Type', 'application/x-www-form-urlencoded'); utl_http.set_header(req, 'Content-Length', length(postData)); -- optionally, you might want to set User Agent header utl_http.set_header(req, 'User-Agent', 'MyCoolHttpClientFromWSAccessPkg/1.5'); -- send data: this function handles URL encoding for us! utl_http.write_text(req, postData); -- read the response resp := utl_http.get_response(r => req); xmlData := ''; begin loop utl_http.read_text(r => resp, data => v_msg); xmlData := xmlData || v_msg; end loop; exception when utl_http.end_of_body then null; end; -- end response utl_http.end_response(r => resp); return xmlData; end executews; end wsaccess_pkg;
You could also parse the XML response and return a pure PL/SQL object. That's even better. But I would probably talk about in a separate blog entry.
Do you have an example of the RESTful application that consumes the parameters? I'm working on a similar project and would appreciate seeing an example.
ReplyDeleteSure. What programming language are you using?
ReplyDeleteI simply wanted to write down a quick word to say thanks to you for those wonderful tips and hints you are showing on this site."Oracle Training in Bangalore"
ReplyDeleteI ‘d mention that most of us visitors are endowed to exist in a fabulous place with very many wonderful individuals with very helpful things.
ReplyDeleteoracle training in bangalore
Very useful information to everyone thanks for sharing, learn the latest updated Technology at Best Training institutions
ReplyDeleteSalesforce Lightning is the latest updated technology
Salesforce Online Training in Bangalore
Salesforce Training online in India
Great blog! Really awesome I got more information from this blog. Thanks for sharing with us.
ReplyDeleteoracle training center in chennai
oracle training chennai
Very nice post here and thanks for it .I always like and such a super contents of these post.Excellent and very cool idea and great content of different kinds of the valuable information's.
ReplyDeleteGood discussion. Thank you.
Anexas
Six Sigma Training in Abu Dhabi
Six Sigma Training in Dammam
Six Sigma Training in Riyadh
Great blog thanks for sharing Looking for the best creative agency to fuel new brand ideas? Adhuntt Media is not just a digital marketing company in chennai. We specialize in revamping your brand identity to drive in best traffic that converts. Buckle up for a ride that is going to be filled with SEO, Social media marketing, unique Graphic & Logo design and efficient ads strike the perfect chord! Join the Adhuntt Media adventure right at Adhuntt Media.
ReplyDeletedigital marketing company in chennai
Nice blog thanks for sharing Is this a special day for you? Beautiful and fragrant flowers are sure to make it even more amazing of a day no doubt. This is why Karuna Nursery Gardens offers you the best rental plants in Chennai that too at drop dead prices.
ReplyDeleteplant nursery in chennai
Excellent blog thanks for sharing Run your salon business successfully by tying up with the best beauty shop in Chennai - The Pixies Beauty Shop. With tons of prestigious brands to choose from, and amazing offers we’ll have you amazed.
ReplyDeletebeauty Shop in Chennai
Very Nice...
ReplyDeleteinternship in chennai for ece students with stipend
internship for mechanical engineering students in chennai
inplant training in chennai
free internship in pune for computer engineering students
internship in chennai for mca
iot internships
internships for cse students in
implant training in chennai
internship for aeronautical engineering students in bangalore
inplant training certificate
Very useful blog thanks for sharing IndPac India the German technology Packaging and sealing machines in India is the leading manufacturer and exporter of Packing Machines in India.
ReplyDeleteGreat blog indeed.
ReplyDeleteI am glad to read it.Thanks for taking your own time to discuss this topic.
Selenium Training in chennai | Selenium Training in anna nagar | Selenium Training in omr | Selenium Training in porur | Selenium Training in tambaram | Selenium Training in velachery
Excellent Blog! I would Thanks for sharing this wonderful content.its very useful to us.There is lots of Post about Python But your way of Writing is so Good & Knowledgeable. I gained many unknown information, the way you have clearly explained is really fantastic.keep posting such useful information.
ReplyDeletehadoop training in chennai
hadoop training in tambaram
salesforce training in chennai
salesforce training in tambaram
c and c plus plus course in chennai
c and c plus plus course in tambaram
machine learning training in chennai
machine learning training in tambaram
Excellent Blog! I would Thanks for sharing this wonderful content.its very useful to us.
ReplyDeletedata science training in chennai
data science training in omr
android training in chennai
android training in omr
devops training in chennai
devops training in omr
artificial intelligence training in chennai
artificial intelligence training in omr
Worth reading! Our experts also have given detailed inputs about these trainings & courses! Presenting here for your reference. Do checkout Oracle Training In Chennai , Oracle PLSQL Training In Chennai , Oracle DBA Training In Chennai , AWS Training in Chennai & enjoy learning more about it.
ReplyDeleteThanks for the blog and it is really a very useful one.
ReplyDeleteTOGAF Training In Bangalore | TOGAF Online Training
Oracle Cloud Training In Bangalore | Oracle Cloud Online Training
Power BI Training In Bangalore | Power BI Online Training
Alteryx Training In Bangalore | Alteryx Online Training
API Training In Bangalore | API Online Training
Automation Testing with Python Training In Bangalore | Automation Testing with Python Online Training
Study Amazon Web Services for making your career as a shining sun with Infycle Technologies. Infycle Technologies is the best AWS training institute in Chennai, providing complete hands-on practical training of professional specialists in the field. In addition to that, it also offers numerous programming language tutors in the software industry such as Oracle, Python, Big Dat, Hadoop, etc. Once after the training, interviews will be arranged for the candidates, so that, they can set their career without any struggle. Of all that, 200% placement assurance will be given here. To have the best career, call 7502633633 to Infycle Technologies and grab a free demo to know more.No.1 AWS Training Institute in Chennai | Infycle Technologies
ReplyDeleteInfycle Technologies, the No.1 software training institute in Chennai offers the No.1 Big Data Hadoop Training in Chennai | Infycle Technologies for students, freshers, and tech professionals. Infycle also offers other professional courses such as DevOps, Artificial Intelligence, Cyber Security, Python, Oracle, Java, Power BI, Selenium Testing, Digital Marketing, Data Science, etc., which will be trained with 200% practical classes. After the completion of training, the trainees will be sent for placement interviews in the top MNC's. Call 7502633633 to get more info and a free demo.
ReplyDeleteNice thanks for sharing informative post like this keep posting if like more details visit my website linkhttps://snowflakemasters.in/
ReplyDelete