Section courante

A propos

Section administrative du site

Fiche technique
Type de produit : Langage de programmation
Auteur : Real Time Logic
Date de publication : 2003

Introduction

Le CSP, tirant son nom de l'abréviation de l'anglicisme «C Server Pages», permet d'intégrer du code C et C++ dans un fichier HTML standard. Le code C et C++ intégré au HTML peut communiquer directement avec votre application et/ou votre matériel.

Le compilateur CSP est conçu pour être exécuté de manière autonome sur un ordinateur hôte et est généralement exécuté via un makefile. La plupart de des exemples de makefiles utilisent le compilateur/éditeur de liens CSP. Le compilateur CSP traduit un fichier CSP en un fichier C/C++ contenant une HttpPage. Le fichier CSP est un moyen plus simple de créer une HttpPage étendue. Le HttpPage généré est compilé en code objet à l'aide de votre compilateur C ou C++ cible.

Le compilateur CSP permet à un concepteur Web de concevoir le cadre d'une page sans aucune connaissance de C ou C++, et un programmeur C ou C++ peut ensuite ajouter le contenu dynamique à la page. Si le cadre HTML doit être modifié ultérieurement, le concepteur Web peut utiliser son outil HTML préféré pour modifier la page. Tous les outils HTML laissent de côté les balises HTML inconnues et le code C ou C++ intégré à la page ne sera pas modifié.

Les fonctionnalités offertes par notre technologie CSP sont également similaires à celles offertes par les pages ASP (Active Server Pages) de Microsoft. Ainsi, les programmeurs ASP devraient également avoir plus de facilité avec notre environnement de script.

Une HttpPage est comparable à une servlet Java. Le compilateur CSP traduit un fichier CSP en une HttpPage. Un visiteur demandant une page oblige le serveur Web à rechercher la page à l'aide du système de fichiers virtuel. Lorsque la page est trouvée, le Web-Server appelle la fonction de service de page étant automatiquement générée par le compilateur CSP pour une page CSP.

Le code CSP ci-dessus ne contient que des éléments HTML statiques et l'objet de requête passé en paramètre à la fonction de service n'est pas utilisé par le code HTML CSP ci-dessus. Le HttpPage généré pour l'exemple ci-dessus écrit le code HTML statique dans l'objet de réponse, mais l'exemple ci-dessus ne sert qu'à illustrer le fonctionnement conceptuel d'une page CSP. Le code HTML réel n'est pas émis comme ci-dessus, mais est extrait d'un fichier cspPages.dat généré par l'outil CspLink.

Bien que l'exemple ci-dessus contenant uniquement du HTML statique fonctionne, la force de la technologie CSP réside dans les applications Web servant du contenu dynamique. Les pages CSP sont généralement composées de :

Vous pouvez ainsi créer et maintenir des pages CSP par des outils HTML/XML conventionnels. Voici un exemple de script Web-Counter simple pouvant être compilé par CspCompile :

  1. <%! int myCount; %>
  2. <%!! this->myCount = 0; %>
  3. <HTML>
  4. <BODY>
  5. <P> Cette page Web a été visitée
  6. <%HttpResponse_printf(response, "%d ",this->myCount++);%>
  7. nombre de fois</P>
  8. </BODY>
  9. </HTML>

Le CspCompiler reconnaît la balise <% comme le début du code C intégré et la balise %> comme la fin de la section de code C intégré.

Le CspCompiler peut également générer du code C++ et le script peut donc être écrit comme suit :

  1. <%! int myCount; %>
  2. <%!! myCount = 0; %>
  3. <HTML>
  4. <BODY>
  5. <P> Cette page Web a été visitée
  6. <%response->printf("%d ",myCount++);%>
  7. nombre de fois </P>
  8. </BODY>
  9. </HTML>

Les deux exemples ci-dessus peuvent également être écrits en C ou C++ comme suit :

  1. <%! int myCount; %>
  2. <%!! this->myCount = 0; %>
  3. <HTML>
  4. <BODY>
  5. <P>
  6. Cette page Web a été visitée<%="%d" this->myCount++%>nombre de fois </P>
  7. </BODY>
  8. </HTML>

Une application Web est généralement composée de pages générées dynamiquement (CSP) et de contenu statique tel que des images GIF, des feuilles de style,... Le CspCompiler peut également compiler du contenu statique, mais cela est inefficace car une HttpPage est générée pour chaque ressource. Une meilleure approche consiste à utiliser une instance HttpResRdr avec une instance ZipIo pour entreposer du contenu statique. Le HttpResRdr avec un ZipIo transforme un fichier ZIP en un système de fichiers en lecture seulement. Le serveur Web combine des répertoires et des pages dans le fichier ZIP et des pages CSP dans le système de fichiers virtuel si le nom du répertoire est le même. Cela signifie qu'un visiteur verra les deux branches du répertoire comme une seule. On peut ainsi avoir certaines pages dans le fichier ZIP et certaines pages en tant que CSP dans le système de fichiers virtuel, et ces pages seront combinées en une seule lors de l'exécution.

Le serveur Web est également livré avec un outil qui simplifie l'intégration du HTML dynamique/statique dans votre système. Le script CspMakeGen Lua peut être utilisé pour générer un makefile pour votre HTML. L'outil peut parcourir de manière récursive un répertoire contenant des fichiers HTML. L'outil générera une dépendance makefile pour tous les .html et .shtml trouvés dans le répertoire et les sous-répertoires.

Ce qui précède a servi d'introduction rapide à notre technologie CSP. Tout programmeur ASP ou JSP devrait pouvoir se familiariser rapidement avec notre technologie CSP.

Code source

Voici des exemples de code source d'utilitaires pour manipuler le CSP (C Server Pages) :

Lien Langage de programmation Description Projet
https://github.com/gladir/corail/blob/master/ASC2CSP.PAS Free Pascal, Turbo Pascal Cette commande permet de convertir un fichier ASCII en code source CSP (C Server Pages). Corail
https://github.com/gladir/corail/blob/master/BIN2CSP.PAS Free Pascal, Turbo Pascal Cette commande permet de convertir un fichier binaire en tableau de code source CSP (C Server Pages). Corail
https://github.com/gladir/corail/blob/master/DBF2CSP.PAS Free Pascal, Turbo Pascal Cette commande permet de convertir un fichier .DBF (DBase III) en format CSP (C Server Pages). Corail


Dernière mise à jour : Samedi, le 13 mai 2023