Interface de programmation d'applications
Le terme API est un acronyme qui signifie «Application Programming Interface».
Pensez à une API comme un menu dans un restaurant. Le menu fournit une liste de plats que vous pouvez commander, ainsi qu'une description de chaque plat. Lorsque vous spécifiez les éléments de menu que vous souhaitez, la cuisine du restaurant fait le travail et vous fournit des plats finis. Vous ne savez pas exactement comment le restaurant prépare ces plats et vous n’avez pas vraiment besoin de le faire.
De même, une API répertorie un ensemble d'opérations que les développeurs peuvent utiliser, ainsi qu'une description de leurs tâches. Le développeur n’a pas nécessairement besoin de savoir comment, par exemple, un système d’exploitation crée et présente une boîte de dialogue «Enregistrer sous». Ils ont juste besoin de savoir qu’elle est disponible pour une utilisation dans leur application.
Ce n’est pas une métaphore parfaite, car les développeurs doivent peut-être fournir leurs propres données à l’API pour obtenir les résultats. C’est donc peut-être plus un restaurant chic où vous pouvez fournir certains de vos propres ingrédients avec lesquels la cuisine travaillera.
Mais c’est globalement exact. Les API permettent aux développeurs de gagner du temps en tirant parti de l’implémentation d’une plate-forme pour effectuer le travail essentiel. Cela permet de réduire la quantité de code nécessaire aux développeurs et de créer davantage de cohérence entre les applications pour la même plate-forme. Les API peuvent contrôler l'accès aux ressources matérielles et logicielles.
Les API simplifient la vie des développeurs
Supposons que vous souhaitiez développer une application pour iPhone. Le système d'exploitation iOS d'Apple fournit un grand nombre d'API, comme tous les autres systèmes d'exploitation, pour vous faciliter la tâche.
Si vous souhaitez intégrer un navigateur Web pour afficher une ou plusieurs pages Web, par exemple, vous n'avez pas à programmer votre propre navigateur Web à partir de rien, uniquement pour votre application. Vous utilisez l'API WKWebView pour incorporer un objet de navigateur WebKit (Safari) dans votre application.
Si vous souhaitez capturer des photos ou des vidéos à partir de la caméra de l'iPhone, vous n'avez pas à écrire votre propre interface de caméra. Vous utilisez l’API de la caméra pour intégrer la caméra intégrée de l’iPhone à votre application. Si les API n’existaient pas pour simplifier les choses, les développeurs d’applications devraient créer leur propre logiciel de caméra et interpréter les entrées du matériel de la caméra. Mais les développeurs de systèmes d’exploitation d’Apple ont fait tout ce travail, les développeurs n’ayant alors plus qu’à utiliser l’API de la caméra pour intégrer une caméra, puis à créer leur application. De plus, lorsque Apple améliorera l'API de l'appareil photo, toutes les applications qui en dépendent en profiteront automatiquement.
Cela s'applique à toutes les plateformes. Par exemple, voulez-vous créer une boîte de dialogue sous Windows? Il y a une API pour ça. Voulez-vous prendre en charge l'authentification par empreinte digitale sur Android? Il existe une API pour cela aussi, vous n’avez donc pas à tester le capteur d’empreintes digitales de chaque fabricant Android. Les développeurs n’ont pas à réinventer la roue encore et encore.
Les API contrôlent l'accès aux ressources
Les API permettent également de contrôler l'accès aux périphériques matériels et aux fonctions logicielles qu'une application n'est peut-être pas autorisée à utiliser. C’est pourquoi les API jouent souvent un rôle important dans la sécurité.
Par exemple, si vous avez déjà visité un site Web et vu un message dans votre navigateur indiquant que celui-ci demande à connaître votre position précise, ce site Web tente d'utiliser l'API de géolocalisation dans votre navigateur Web. Les navigateurs Web exposent des API telles que celle-ci pour faciliter l'accès des développeurs Web à votre position. Ils peuvent simplement demander «Où êtes-vous?» Et le navigateur effectue le travail difficile nécessaire pour accéder au GPS ou aux réseaux Wi-Fi à proximité pour trouver votre position physique.
Ce même principe est utilisé sur les systèmes d'exploitation mobiles modernes comme iOS et Android, où les applications mobiles disposent d'autorisations pouvant être appliquées en contrôlant l'accès aux API. Par exemple, si un développeur tente d'accéder à la caméra via l'API de la caméra, vous pouvez refuser la demande d'autorisation et l'application n'a aucun moyen d'accéder à la caméra de votre appareil.
Les systèmes de fichiers qui utilisent des autorisations, comme ils le font sous Windows, Mac et Linux, ont ces autorisations appliquées par l'API du système de fichiers. Une application typique n’a pas d’accès direct au disque dur physique brut. Au lieu de cela, l'application doit accéder aux fichiers via une API.
Les API sont utilisées pour la communication entre services
Les API sont utilisées pour toutes sortes d'autres raisons. Par exemple, si vous avez déjà vu un objet Google Maps incorporé sur un site Web, celui-ci utilise l'API Google Maps pour incorporer cette carte. Google expose les API de ce type aux développeurs Web, qui peuvent ensuite les utiliser pour importer des objets complexes directement sur leur site Web. Si de telles API n'existaient pas, les développeurs pourraient être amenés à créer leurs propres cartes et à fournir leurs propres données cartographiques simplement pour créer une petite carte interactive sur un site Web.
Et comme il s’agit d’une API, Google peut contrôler l’accès à Google Maps sur des sites Web tiers, en veillant à ce qu’il l’utilise de manière cohérente plutôt qu’en tentant d’incorporer de manière désordonnée un cadre illustrant le site Web de Google Maps, par exemple.
Cela s'applique à de nombreux services en ligne différents. Il existe des API permettant de demander la traduction de texte à partir de Google Traduction ou d'incorporer des commentaires Facebook ou des tweets de Twitter sur un site Web.
La norme OAuth définit également un certain nombre d'API qui vous permettent de vous connecter à un site Web avec un autre service, par exemple, d'utiliser vos comptes Facebook, Google ou Twitter pour vous connecter à un nouveau site Web sans créer de nouveau compte utilisateur pour ce site.. Les API sont des contrats standard qui définissent la manière dont les développeurs communiquent avec un service et définissent le type de sortie que ces derniers doivent s'attendre à recevoir.
Si vous avez réussi à traverser cela, vous aurez une meilleure idée de ce qu'est une API. En fin de compte, vous n'avez pas vraiment besoin de savoir ce qu'est une API, sauf si vous êtes développeur. Toutefois, si vous voyez qu'une plate-forme logicielle ou un service a ajouté de nouvelles API pour divers matériels ou services, il devrait être plus facile pour les développeurs de tirer parti de ces fonctionnalités.