DEV Community

Sh Raj
Sh Raj

Posted on

CURL - All methods and Usage ✅

Title: Unleash the Power of curl: Your Friendly Handbook

Curl isn't just a tool; it's a developer's best friend, capable of tackling a multitude of tasks with ease. From fetching web resources to testing APIs, curl has got your back. In this guide, we'll walk through various functions and methods of curl in a friendly, approachable manner, complete with sample examples explained with a touch of JavaScript.


Basic Fetching:
Let's start with the basics. With curl, you can fetch web resources effortlessly:

curl [URL]
Enter fullscreen mode Exit fullscreen mode

In JavaScript, it's akin to making a simple HTTP GET request using fetch:

fetch('[URL]')
  .then(response => response.text())
  .then(data => console.log(data))
  .catch(error => console.error('Error:', error));
Enter fullscreen mode Exit fullscreen mode

Posting Data:
Need to send data to a server? No problem! With curl, you can easily make POST requests:

curl -X POST -d "key1=value1&key2=value2" [URL]
Enter fullscreen mode Exit fullscreen mode

In JavaScript, it's similar to posting data using fetch:

fetch('[URL]', {
  method: 'POST',
  body: JSON.stringify({ key1: 'value1', key2: 'value2' }),
  headers: {
    'Content-Type': 'application/json'
  }
})
  .then(response => response.json())
  .then(data => console.log(data))
  .catch(error => console.error('Error:', error));
Enter fullscreen mode Exit fullscreen mode

Custom Headers:
You can include custom headers in your requests using curl:

curl -H "Authorization: Bearer [token]" [URL]
Enter fullscreen mode Exit fullscreen mode

In JavaScript, it translates to setting custom headers with fetch:

fetch('[URL]', {
  headers: {
    'Authorization': 'Bearer [token]'
  }
})
  .then(response => response.json())
  .then(data => console.log(data))
  .catch(error => console.error('Error:', error));
Enter fullscreen mode Exit fullscreen mode

Following Redirects:
Sometimes, you need to follow redirects. Curl makes it easy:

curl -L [URL]
Enter fullscreen mode Exit fullscreen mode

In JavaScript, fetch follows redirects by default, so no extra steps are needed!

Authentication:
Curl supports various authentication methods. For example, using Basic authentication:

curl -u username:password [URL]
Enter fullscreen mode Exit fullscreen mode

In JavaScript, you can pass credentials in the request headers:

fetch('[URL]', {
  headers: {
    'Authorization': 'Basic ' + btoa('username:password')
  }
})
  .then(response => response.json())
  .then(data => console.log(data))
  .catch(error => console.error('Error:', error));
Enter fullscreen mode Exit fullscreen mode

Testing APIs:
Curl is perfect for testing APIs. You can inspect response headers, status codes, and response bodies easily:

curl -i [URL]
Enter fullscreen mode Exit fullscreen mode

In JavaScript, fetch gives you access to all this information:

fetch('[URL]')
  .then(response => {
    console.log('Status:', response.status);
    console.log('Headers:', response.headers);
    return response.json();
  })
  .then(data => console.log('Data:', data))
  .catch(error => console.error('Error:', error));
Enter fullscreen mode Exit fullscreen mode

Conclusion:
Curl is more than just a tool; it's a Swiss Army knife for developers. With its simplicity and power, you can conquer a wide range of tasks effortlessly. Whether you're fetching resources, testing APIs, or sending data to servers, curl has got you covered.

So, next time you need to interact with web services from the command line or your JavaScript code, remember your trusty companion, curl! 🚀

Top comments (1)