> Tech > Serveur PHP REST

Serveur PHP REST

Tech - Par Renaud ROSSET - Publié le 24 juin 2010
email

Le serveur PHP REST de la figure 8 renverra un document XML NameListResponse.xsd au client. Nous n’appliquons que la méthode de requête HTTP GET dans l’exemple suivant ; les autres verbes REST – DELETE, PUT et POST – renverront HTTP/1.0 400 Bad Request via l’API PHP header().

Serveur PHP REST

La méthode de requête GET appelle nameListXML() pour ouvrir une connexion vers DB2 avec une requête de la table nobody/names pour obtenir une liste de noms. L’utilisation de db2_pconnect() autorise une connexion persistante sur le profil de job par défaut (profil NOBODY), ce qui peut améliorer nettement la performance du script, car il est appelé répétitivement par les clients.

Je n’ai pas imposé le contrat maxOccurs NameListResponse.xsd de NameList Response.xsd. Dans la fonction nameListXML($xmlrow), nous utilisons un opérateur de concaténation de chaîne fourni par le langage PHP ($xmlrow = « add more string ») pour construire le complet avant de le renvoyer en écho à l’appelant.

Astuce : La possibilité qu’a PHP de rechercher, construire et modifier dynamiquement des chaînes est très utile pour de nombreuses tâches Web.

Si vous prenez le temps d’apprendre les expressions normales dans PHP (malgré la syntaxe bizarre), vous constaterez que la manipulation de chaînes de PHP est nettement supérieure aux structures de traitement de chaînes de Net.Data.

Téléchargez cette ressource

Percer le brouillard des rançongiciels

Percer le brouillard des rançongiciels

Explorez les méandres d’une investigation de ransomware, avec les experts de Palo Alto Networks et Unit 42 pour faire la lumière dans la nébuleuse des rançongiciels. Plongez au cœur de l’enquête pour comprendre les méthodes, les outils et les tactiques utilisés par les acteurs de la menace. Découvrez comment prévenir les attaques, les contrer et minimiser leur impact. Des enseignements indispensables aux équipes cyber.

Tech - Par Renaud ROSSET - Publié le 24 juin 2010