curl कमांड्स को Ruby कोड में बदलें - API अनुरोधों के लिए तुरंत उपयोग करने योग्य Ruby Net::HTTP कोड जनरेट करें
# Ruby Net::HTTP code will appear here # Example: require 'net/http' require 'uri' require 'json' uri = URI.parse('https://api.example.com/data') http = Net::HTTP.new(uri.host, uri.port) http.use_ssl = true if uri.scheme == 'https' request = Net::HTTP::Post.new(uri.path) request['Content-Type'] = 'application/json' request.body = JSON.dump({name: 'test'}) response = http.request(request) puts response.code puts response.body
यहां कुछ सामान्य curl कमांड्स हैं जिन्हें आप Ruby कोड में बदल सकते हैं:
curl https://api.example.com/users
curl -X POST -H "Content-Type: application/json" -d '{"name":"John","email":"[email protected]"}' https://api.example.com/users
curl -X PUT -H "Authorization: Bearer token123" -d '{"status":"active"}' https://api.example.com/users/1
curl -X DELETE https://api.example.com/users/1
curl -H "X-API-Key: abc123" -H "Accept: application/json" https://api.example.com/data
Ruby की Net::HTTP लाइब्रेरी HTTP अनुरोध करने का एक शक्तिशाली तरीका है। यहां कुछ सामान्य Ruby Net::HTTP पैटर्न हैं:
require 'net/http' require 'uri' uri = URI.parse('https://api.example.com/upload') http = Net::HTTP.new(uri.host, uri.port) http.use_ssl = true if uri.scheme == 'https' request = Net::HTTP::Post.new(uri.path) request['Authorization'] = 'Bearer YOUR_TOKEN_HERE' # Create multipart form data boundary = "AaB03x" post_body = [] post_body << "--#{boundary}\r\n" post_body << "Content-Disposition: form-data; name=\"file\"; filename=\"document.pdf\"\r\n" post_body << "Content-Type: application/pdf\r\n\r\n" post_body << File.read('document.pdf') post_body << "\r\n--#{boundary}--\r\n" request['Content-Type'] = "multipart/form-data; boundary=#{boundary}" request.body = post_body.join response = http.request(request) puts response.body
require 'net/http' require 'uri' require 'json' uri = URI.parse('https://api.example.com/data') http = Net::HTTP.new(uri.host, uri.port) http.use_ssl = true if uri.scheme == 'https' http.open_timeout = 5 # seconds http.read_timeout = 5 # seconds begin request = Net::HTTP::Get.new(uri.request_uri) response = http.request(request) case response when Net::HTTPSuccess data = JSON.parse(response.body) puts data else puts "Error: #{response.code} - #{response.message}" end rescue Net::OpenTimeout puts "Connection timed out" rescue Net::ReadTimeout puts "Response timed out" rescue StandardError => e puts "Error making request: #{e.message}" end
अपना curl कमांड कॉपी करें → इनपुट बॉक्स में पेस्ट करें → कन्वर्ट किया गया Ruby Net::HTTP कोड प्राप्त करें
हमारा कन्वर्टर जटिल curl कमांड्स को समर्थित करता है और उन्हें Net::HTTP लाइब्रेरी का उपयोग करके क्लीन, कुशल Ruby कोड में अनुवादित करता है
हमारा टूल इन सामान्य curl विकल्पों को संभालता है और उन्हें उपयुक्त Ruby Net::HTTP कोड में बदलता है:
उत्तर: जनरेट किए गए Ruby Net::HTTP कोड Ruby 2.0 और उससे ऊपर के साथ कंपैटिबल है। पुराने Ruby वर्जन के लिए, मामूली समायोजन की आवश्यकता हो सकती है।
उत्तर: बेसिक जनरेट किया गया कोड व्यापक एरर हैंडलिंग शामिल नहीं करता है। प्रोडक्शन कोड के लिए, आपको Net::HTTPError या कनेक्शन मुद्दों जैसे संभावित अपवादों को हैंडल करने के लिए begin/rescue ब्लॉक्स जोड़ने चाहिए।
उत्तर: JSON रिस्पॉन्स के लिए, रिस्पॉन्स को Ruby हैश में पार्स करने के लिए JSON.parse(response.body) का उपयोग करें। अन्य फॉर्मेट के लिए, आप रॉ कंटेंट के लिए response.body का उपयोग कर सकते हैं।
उत्तर: Net::HTTP लाइब्रेरी Ruby की स्टैंडर्ड लाइब्रेरी का हिस्सा है, इसलिए बेसिक HTTP अनुरोधों के लिए किसी अतिरिक्त जेम की आवश्यकता नहीं है। JSON हैंडलिंग के लिए, 'json' जेम Ruby 1.9 से स्टैंडर्ड लाइब्रेरी में शामिल है।
उत्तर: Ruby में फाइल अपलोड के लिए, आपको Net::HTTP के साथ मल्टीपार्ट फॉर्म डेटा का उपयोग करने की आवश्यकता होगी। हमारा कन्वर्टर -F
या --form
विकल्पों वाले curl कमांड्स को संभालता है और उपयुक्त Ruby कोड जनरेट करता है।
उत्तर: Ruby की Net::HTTP लाइब्रेरी HTTP::Cookie जार के माध्यम से कुकी हैंडलिंग प्रदान करती है। जब आप कुकी हैंडलिंग (-b
या --cookie
का उपयोग करके) वाले curl कमांड्स को कन्वर्ट करते हैं, तो हमारा टूल कुकीज को ठीक से प्रबंधित करने वाला Ruby कोड जनरेट करता है।
उत्तर: जबकि curl त्वरित कमांड-लाइन API टेस्टिंग के लिए उत्कृष्ट है, Ruby Net::HTTP एक प्रोग्रामेटिक दृष्टिकोण प्रदान करता है जो आपके Ruby एप्लिकेशन के साथ एकीकृत होता है। curl को Ruby में बदलना Ruby डेवलपमेंट में टेस्टिंग और इम्प्लीमेंटेशन के बीच की खाई को पाटने में मदद करता है।
Ruby के साथ प्रभावी API टेस्टिंग के लिए curl कमांड्स को समझना आवश्यक है। यहां सामान्य curl विकल्पों का एक त्वरित संदर्भ है जिसे हमारा कन्वर्टर समर्थित करता है:
curl [options] [URL]
-X, --request METHOD
: Specify request method (GET, POST, PUT, DELETE, etc.)-H, --header LINE
: Add header to the request-d, --data DATA
: Send data in POST request-F, --form CONTENT
: Submit form data-u, --user USER:PASSWORD
: Server user and password-k, --insecure
: Allow insecure server connections-I, --head
: Show document info only-v, --verbose
: Make the operation more verbose-s, --silent
: Silent mode--connect-timeout SECONDS
: Maximum time for connectionहमारा Ruby कन्वर्टर मल्टीपल हेडर्स, ऑथेंटिकेशन, डेटा पेलोड और विभिन्न विकल्पों सहित जटिल curl कमांड्स को संभालता है। बस अपना curl कमांड पेस्ट करें और Net::HTTP लाइब्रेरी का उपयोग करके क्लीन, मॉडर्न Ruby कोड प्राप्त करें।
Ruby Net::HTTP लाइब्रेरी के साथ काम करते समय, कुशल और सुरक्षित API इंटरैक्शन के लिए इन बेस्ट प्रैक्टिसेज का पालन करें:
require 'net/http' require 'uri' uri = URI.parse('https://api.example.com') Net::HTTP.start(uri.host, uri.port, use_ssl: uri.scheme == 'https') do |http| # First request request1 = Net::HTTP::Get.new('/users') response1 = http.request(request1) # Second request (uses same connection) request2 = Net::HTTP::Get.new('/products') response2 = http.request(request2) end
require 'net/http' require 'uri' uri = URI.parse('https://api.example.com/data') begin response = Net::HTTP.get_response(uri) case response when Net::HTTPSuccess puts "Success: #{response.body}" when Net::HTTPRedirection puts "Redirection to: #{response['location']}" when Net::HTTPClientError puts "Client error: #{response.code} - #{response.message}" when Net::HTTPServerError puts "Server error: #{response.code} - #{response.message}" else puts "Unknown response: #{response.code} - #{response.message}" end rescue SocketError => e puts "Connection error: #{e.message}" rescue Timeout::Error puts "Connection timed out" rescue StandardError => e puts "Error: #{e.message}" end
require 'net/http' require 'uri' require 'json' uri = URI.parse('https://api.example.com/data') response = Net::HTTP.get_response(uri) begin data = JSON.parse(response.body) puts data['name'] rescue JSON::ParserError => e puts "Invalid JSON response: #{e.message}" end