DEV Community

Cover image for How to Track Flight Status in real-time using the Flight Tracker API
Salvietta150x40
Salvietta150x40

Posted on • Edited on • Originally published at ma-no.org

How to Track Flight Status in real-time using the Flight Tracker API

The Flight Tracker API provides developers with the ability to access real-time flight status, which is extremely useful for integrating historical tracking or live queries of air traffic into your website.

With this API, you can easily track the status of a flight and access airport schedules.

There are several Flight Tracker APIs available to retrieve flight status, and one of the best options is aviationstack. This API offers a simple way to access aviation data globally, including real-time flight status and airport schedules.

Aviationstack tracks every flight worldwide at all times, storing the information in its database and providing real-time flight status through its API. It is a user-friendly REST API that returns responses in JSON format and is compatible with various programming languages such as PHP, Python, Ruby, Node.js, jQuery, Go, and more.

In this tutorial, we will show you how to obtain real-time flight status using the aviationstack Flight Tracker API with PHP.

 

Obtaining API Credentials

 

To get started, you need to create an account on aviationstack. Once you are in your dashboard, you can copy the API access key from the "Your API Access Key" section.

 

API Configuration

 

We will need the access key to authenticate and access the aviationstack API.

Next, we will build the query using the http_build_query()  function to pass the necessary parameters to the aviationstack API.

Define the access key in the access_key  parameter.

 

$queryString = http_build_query([
'access_key' => 'YOUR_ACCESS_KEY'
]);

 

HTTP GET Request

 

To retrieve flight data, we will make an HTTP GET request to the aviationstack API using cURL.

 

// API URL with the query string
$apiURL = sprintf('%s?%s', 'https://api.aviationstack.com/v1/flights', $queryString);
// Initialize cURL
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $apiURL);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
// Execute the API request
$api_response = curl_exec($ch);
// Close cURL
curl_close($ch);

 

It is important to ensure that the API call is secure, so we should use the URL with https :

https://api.aviationstack.com

 

Flight Status and General Information

 

After making the API call, we will receive the current flight status and related information in JSON format. Initially, the aviationstack API provides the following geolocation data:

- Flight date (flight_date)
- Flight status (flight_status)
- Departure and arrival information (departure/arrival)
- airport
- timezone
- iata
- icao
- terminal
- gate
- delay
- scheduled
- estimated
- actual
- estimated_runway
- actual_runway

- Airline information (airline)
- name
- iata
- icao

- Flight information (flight)
- number
- iata
- icao
- codeshared

- Aircraft information (aircraft)
- registration
- iata
- icao
- icao24

- Live data (live)
- updated
- latitude
- longitude
- altitude
- direction
- speed_horizontal
- speed_vertical
- is_ground

By using the json_decode()  function, we can convert the obtained JSON data into a PHP array.

Here's an example of how to extract flight information using the aviationstack API:

 

$api_result = json_decode($api_response, true);

 

Below is the complete code to retrieve global flight information using the aviationstack API with PHP:

 


// Define the API access key
$queryString = http_build_query([
'access_key' => 'YOUR_ACCESS_KEY',
'limit' => 10
]);
// API URL with the query string
$apiURL = sprintf('%s?%s', 'https://api.aviationstack.com/v1/flights', $queryString);
// Initialize cURL
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $apiURL);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
// Execute the API request
$api_response = curl_exec($ch);
// Close cURL
curl_close($ch);
// Convert the JSON into an array
$api_result = json_decode($api_response, true);
// Display flight data
foreach ($api_result['data'] as $flight) {
if (!$flight['live']['is_ground']) {
echo sprintf("%s flight %s from %s (%s) to %s (%s) is in the air.",
$flight['airline']['name'],
$flight['flight']['iata'],
$flight['departure']['airport'],
$flight['departure']['iata'],
$flight['arrival']['airport'],
$flight['arrival']['iata']
), PHP_EOL;
echo '<br/>';
}
}
?>

 

This code allows you to retrieve updated flight information using the aviationstack API. Make sure to replace ' YOUR_ACCESS_KEY ' with your provided personal access key from aviationstack.

You can integrate this code into your PHP application to display real-time flight status and related details on your website.

Note: It's important to handle error cases, such as when the API response is not successful or when there are no flight data available. You can add error handling and additional logic as per your application requirements.

Top comments (2)

Collapse
 
olodocoder profile image
Adams Adebayo

Hi Salvietta,

This is a very insightful article. However, the formatting is off. Try these things:

  • add the respective language to the code blocks. For example, this looks better:
   $api_result = json_decode($api_response, true);
Enter fullscreen mode Exit fullscreen mode
  • put the long list in a table
  • use proper headings. For example, this looks better:

Flight Status and General Information

I believe fixing these will make the article more appealing to readers.

Collapse
 
salvietta150x40 profile image
Salvietta150x40

Hi Adams, thanks for the advice!
I actually tried formatting with the basic markdown editor and didn't succeed very well.
I will try to change it