The World’s Best Query-Based Flight Tracking and Flight Status API

AeroAPI (formerly FlightXML) delivers customized access to developers seeking data from millions of flight status inputs for any application using REST/JSON.

Start making queries to power your application. Kademeleri Şimdi Karşılaştır

Temel Özellikler

  • Easy to integrate, flexible, and scalable
  • Modern REST-based
  • Real-time and configurable flight event alerts
  • Comprehensive developer documentation and interactive portal
  • Predictive ETAs, powered by ForesightTM
  • Customizable aviation data to meet your unique application needs
  • 99.5% uptime guarantee available
  • Compatible with all programming languages

Uçuş Verilerini İsteğe Göre Sorgulayın

AeroAPI, yazılım geliştiricilerin FlightAware'in pek çok uçuş verisine erişmesini sağlayan basit, sorgu bazlı bir API'dır. Kullanıcılar güncel ve geçmiş verilere ulaşabilirler. AeroAPI bir RESTful API'ıdır ve doğru, uygulanabilir havacılık verisi sağlar. ForesightTM'ın eklenmesiyle müşteriler ABD'deki tahminî ETA'ların yarısından fazlasının çalışmasını sağlayan verilere erişim sağlarlar.

Query AeroAPI for Flights Based on a Combination Of Properties Including

  • Uçuş veya kuyruk numarası
  • Başlangıç noktası ve/veya varış havaalanı
  • Uçak türü
  • Yavaştan hızlıya irtifa
  • Yavaştan hızlıya yer sürati

Retrieve Flight Data Through AeroAPI Including:

  • Flight or tail number
  • Aircraft type
  • Origin and/or destination airport
  • Time last position was received
  • Boylam, enlem, yer sürati ve irtifa
  • ForesightTM, FlightAware’s predictive ETAs
  • And more

API aracılığıyla havaalanı merkezli veriler elde edin, buna şunlar dâhildir:

  • Scheduled flights
  • Kalkan uçuşlar
  • Yoldaki uçuşlar
  • Varan uçuşlar

AeroAPI Kod Örnekleri

import requests

apiKey = input("API Key: ")
apiUrl = "https://aeroapi.flightaware.com/aeroapi/"

airport = 'KSFO'
payload = {'max_pages': 2}
auth_header = {'x-apikey':apiKey}

response = requests.get(apiUrl + f"airports/{airport}/flights",
    params=payload, headers=auth_header)

if response.status_code == 200:
    print(response.json())
else:
    print("Error executing request")
String YOUR_API_KEY = "API_KEY_HERE";
String apiUrl = "https://aeroapi.flightaware.com/aeroapi/";

String airport = "KSFO";

HttpClient client = HttpClient.newHttpClient();
HttpRequest request = HttpRequest.newBuilder()
	.uri(URI.create(apiUrl + "airports/" + airport + "/flights"))
	.headers("x-apikey", YOUR_API_KEY)
	.build();
HttpResponse response = client.send(request, BodyHandlers.ofString());

if (response.statusCode() == 200) {
	System.out.println("responseBody: " + response.body());
}
<?php
$apiKey = "YOUR_API_KEY";
$fxmlUrl = "https://aeroapi.flightaware.com/aeroapi/";

$ident = 'SWA45';
$queryParams = array(
	'max_pages' => 2
);
$url = $fxmlUrl . 'flights/' . $ident . '?' . http_build_query($queryParams);

$ch = curl_init($url);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('x-apikey: ' . $apiKey));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);

if ($result = curl_exec($ch)) {
	curl_close($ch);
	echo $result;
}
?>
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text.Json;
using System.Text.Json.Serialization;
using System.Threading.Tasks;

namespace AeroApi4Sample
{
    public class FlightsResult
    {
        public List Flights { get; set; }
    }

    public class Flight
    {
        public string Ident { get; set; }

        [JsonPropertyName("fa_flight_id")]
        public string FaFlightId { get; set; }

        [JsonPropertyName("scheduled_out")]
        public DateTime ScheduledOut { get; set; }
        
        [JsonPropertyName("actual_out")]
        public DateTime? ActualOut { get; set; }
    }

    public class Program
    {
        static void Main( string[] args )
        {
            Console.Write( "API Key: " );
            var strApiKey = Console.ReadLine();

            Console.Write( "Ident to look up (e.g., UAL47): " );
            var strIdentToLookUp = Console.ReadLine();

            var flights = GetFlights( strApiKey, strIdentToLookUp ).Result;
            
            if( flights == null )
            {
                return;
            }

            var nextFlightToDepart = flights.Where( 
                f => f.ActualOut == null 
                ).OrderBy( f => f.ScheduledOut ).First();

            Console.WriteLine( 
                string.Format( 
                    "Next departure of {0} is {1} at {2}", 
                    strIdentToLookUp,
                    nextFlightToDepart.FaFlightId, 
                    nextFlightToDepart.ScheduledOut 
                    ) 
                );
        }

        private static async Task> GetFlights( string strApiKey, string strIdent )
        {
            using( var client = new HttpClient() )
            {
                client.DefaultRequestHeaders.Accept.Clear();
                client.DefaultRequestHeaders.Accept.Add(
                    new MediaTypeWithQualityHeaderValue( "application/json" )
                    );
                client.DefaultRequestHeaders.Add( 
                    "x-apikey", 
                    strApiKey 
                    );

                FlightsResult flightResult = null;
                var response = await client.GetAsync(
                    "https://aeroapi.flightaware.com/aeroapi/flights/" + strIdent
                    );
                var contentStream = await response.Content.ReadAsStreamAsync();

                if( response.IsSuccessStatusCode )
                {
                    flightResult = await JsonSerializer.DeserializeAsync(
                        contentStream, 
                        new JsonSerializerOptions 
                        {
                            PropertyNameCaseInsensitive = true
                        }
                        );
                }
                else
                {
                    Console.Error.WriteLine( "API call failed: " + response );
                    return null;
                }

                return flightResult.Flights;
            }
        }
    }
}

AeroAPI Python, Ruby, Java, .NET ve diğer dillerle de kullanılabilir.

AeroAPI Sorgu Ücretleri

Tek bir Sorgu, yapılan arama türüne ve sunulan girdi parametresine bağlı olarak çok fazla sonuç çıkarabilir. Fiyatlandırma amaçları gereğince, 15 sonuç/kayıt şeklinde bir 'sonuç seti' belirlenmiştir. Fiyatlandırma sonuç seti başına gerçekleşir.

Not: max_pages girdi parametresi kaç sonuç çıkacağını sınırlamak/kontrol etmek amacıyla kullanılabilir, bir sayfa bir sonuç seti anlamına gelir.

Not: max_pages girdi parametresi kaç sonuç çıkacağını sınırlamak/kontrol etmek amacıyla kullanılabilir, bir sayfa bir sonuç seti anlamına gelir.

Sorgulama yapmaya bugün başlayın! Kademeleri Karşılaştır

Dünya Genelindeki Organizasyonlar Tarafından Kullanılıyor

Frequently Asked Questions

How am I charged when the API returns multiple results for one query?

In general, you are charged once per query. However, for queries that may return multiple pages of results (defined as sets of up to 15 results), you will be charge for the total number of pages returned (calculated as the per-query fee times the number of pages returned). You can control the maximum number of pages returned by the API for one query. Please refer to the API documentation for details on how to set the "max_pages" parameter.

How can I view my AeroAPI billing status?

Existing customers can visit the AeroAPI portal to see accrued charges.

What is new in version 4?

Version 4 features more detailed results on flight queries and push alerts so you get the same or more information with fewer calls. We redesigned the API to provide an easier to use RESTful interface. The all-new interactive web portal allows you to explore the API and try it without writing any code. A 99.5% uptime guarantee is also now available.

I use version 2 or version 3 of AeroAPI, what is the future of these products?

Version 2 and version 3 of AeroAPI will continue to be available to existing customers until October 31, 2023 and their respective pricing is unchanged. These legacy products are no longer available for new sign-ups. We encourage legacy AeroAPI customers to plan to adopt the new version of AeroAPI in the near future so that they will not be impacted by the end-of-life of the old products in 2023. Additionally, customers on the new version of AeroAPI will receive access to future updates of AeroAPI without changing to a new product.

I use version 2 or version 3 of AeroAPI, how can I switch to version 4?

You can get started with the new version of AeroAPI today, just sign-up on-line. As an existing AeroAPI customer, the monthly minimum fee is waived for the first 3 months of your new subscription at the Standard or Premium tier to help you get started.

Belgeler

FlightAware's API for flight status, flight tracking and aviation data can be accessed via REST and the API can be accessed using any programming language.

Support

Genel sorulara cevaplar bulmak için lütfen SSS bölümümüzü ziyaret edin veya daha derinlemesine bilgiler için tartışma forumumuza göz atın.

Giriş

Hesabınız yok mu? Kişiselleştirilmiş özellikler, uçuş uyarıları ve daha fazlası için şimdi (ücretsiz) üye olun!
Bu web site tanımlama bilgileri kullanmaktadır. Bu web siteyi kullanarak ve bu sitede gezinerek, bunu kabul etmiş olursunuz.
Kapat
FlightAware uçuş takibinin reklamlarla desteklendiğini biliyor muydunuz?
FlightAware.com'dan gelen reklamlara izin vererek FlightAware'in ücretsiz kalmasını sağlamamıza yardım edebilirsiniz. harika bir deneyim sunmak adına reklamlarımızı anlamlı ve öne çıkmayacak şekilde tutmak için yoğun şekilde çalışıyoruz. FlightAware'deki whitelist adsreklamları güvenilir olarak görmek hızlı ve kolaydır, veya lütfen premium hesaplarımıza geçmeyi düşünün.
Kapat