Designed by Gaetan !
27 en ligne   Boutique | Sites | Bar | Forum | PhpBB | Actu | Glossaire | Codes | Tips | Liens | Livres | Lettre  


 Recherche

 NewsLetter





   

Connexions facilitées (ASP)

Un include pour vous simplifier la vie





Langage utilisé :

Voilà maintenant un moment que je travaille avec l'ASP, et qu'à chaque fois j'écris le même code pour gérer mes bases de données. C'est rébarbatif, et c'est aussi une belle perte de temps.
La solution ?? Elle existe, elle est simple et vous l'utilisez à chaque fois que vous codez en ASP. C'est le VBScript, qui permet de créer des fonctions et des procédures.

Voilà le principe : Vous créez un fichier (par exemple fonctions.asp) qui contiendra différentes fonctions et méthodes pour la gestion des bases de données. Ensuite, il suffit de mettre ce fichier en include à chaque fois que vous en avez besoin.

Je vous montre un exemple (c'est le fichier que j'utilise moi-même).
<%
' ****************************************************************************
'               Script réutilisable permettant de simplifier et d'exporter
'    au maximum les connexions au bases de données. Permet l'ouverture et 
'      la fermeture d'une connexion, la création, la destruction d'un recordset, 
'        la création d'une liste déroulante, l'envoi d'email avec CDONTS, etc...
' ****************************************************************************

' ****************************************************************************
' Manipulation de la base de données

' ****************************************************************************


' Déclarations des variables utilisées tout au long du script :

Dim oConn   ' object connexion


' Connexion à la base :

Sub Connexion()
   sConn = "PROVIDER=MSDASQL;DRIVER={Microsoft Access Driver (*.mdb)}; DBQ=" & Application("maBase")
   Set oConn = Server.CreateObject("ADODB.Connection")
   oConn.Open sConn
End Sub


' Execution d'une requête sans attendre de résultat (requêtes d'insertion, de mise à jour, ...)

Sub Execution(sReq)
   If sreq <> "" then
      oConn.Execute(sReq)
   else
      response.write("<b>Erreur E001 : Exécution d'une requête</b><br>")
      response.write("Le paramètre envoyé est vide."<br>")
   end if
End Sub


' Vérification qu'un recordSet n'est pas vide

Function estVide(ByRef rstReq)
   If rstReq.eof OR rstReq.bof then
      estVide = true
   else
      rstreq.movefirst
      estVide = false
   end if
end function


' Ouverture d'un recordset pour le mode page a page :

Sub Ouverture(sReq, ByRef rstReq, nb)
   Set rstReq = Server.CreateObject("ADODB.RecordSet")
   If nb <> "" And nb <> "0" then
      rstReq.CursorLocation = 3
      rstReq.PageSize = CInt(nb)
   end if
   rstReq.Open sReq, oConn, 3, 3
End Sub


' Remplissage d'une zone de liste avec un recordset :

Sub CreeSelect(ByRef rstReq, iVal1, iVal2)
   If Not estVide(rstReq) Then
      Do Until rstReq.Eof
         response.write("<option value='"&rstReq(iVal1)&"'>")
         response.write(rstReq(iVal2))
         response.write("</option>")
         rstReq.MoveNext
      Loop
   Else
      response.write("<option value='NULL'>Aucune entrée</option>")
   End If
End Sub


' Fermer un recordset :

Sub Fermeture(ByRef rstReq)
   if isObject(rstReq) then
      rstReq.Close
      Set rstReq = Nothing
   else
      response.write("<b>Erreur F001 : Fermeture d'un RecordSet</b><br>")
      response.write("Le paramètre envoyé à la fonction de fermeture n'esiste pas ou n'est pas un object.<br>")
   End If
End Sub


' Envoyer un e-mail

sub envoiMail(paramExpediteur, paramDestinataire, paramSujet, paramCorps, paramTypeMail)
   Set objCDOMail = Server.CreateObject("CDONTS.NewMail")
      
                ' Renseignement des propriétés
   objCDOMail.From = paramExpediteur
   objCDOMail.To = paramDestinataire
   objCDOMail.Subject = paramSujet
   objCDOMail.Importance = 1 '(0=Low, 1=Normal, 2=High)
   objCDOMail.BodyFormat = paramTypeMail '(HTML or TEXT format)
   if paramTypeMail = 0 then
      objCDOMail.MailFormat = 0 '(Mime format)
   end if

                ' Corps du message
   objCDOMail.Body = paramCorps   
   
                ' Send the message!
   objCDOMail.Send
   Set objCDOMail = Nothing
end sub


' Déconnexion :

Sub Deconnexion()
   oConn.Close
   Set oConn = Nothing
End Sub
%>

Bon, c'est pas encore le top. Faudrait rajouter la gestion des erreurs, un mode d'emploi(?) et d'autres fonctions utiles.

Il suffit juste d'initialiser dans le global.asa la variable d'application "mabase" et c'est bon, ça marche partout.


UTILISATION :

Ben c'est facile. On met le fichier en include et après, on appelle les méthodes comme ceci :

<!-- #include file="fonctions.asp"--> 
<%
Dim maRequete, monRecordSet

maRequete = "SELECT * FROM maTable"

Ouverture maRequete, monRecordSet, 0  ' le 0 c pour afficher tous les elt sans page a page

%>


<!-- code html de la page -->

<% CreeSelect monRecordSet, "champ_Valeur", "champ_Intitule" %>

<!-- code html -->

<%
Fermeture(monRecordSet)

Deconnexion
%>


Voilà, j'espère que ça vous sera utile, et n'hésitez pas à me faire parvenir vos modifications et vos nouvelles idées !!

guitoux1@caramail.com

P.S. : J'ai aussi une gestion des variables de type tableau, mais bon, c'est pas encore assez indépendant pour être utilisé partout. Faut que je travaille ca...

Guitoux1 le 22/09/2003 (25 106 hits)
Didier Téléchargez 1200 Partitions Gratuites !!!
Au fil des news  
Amélioration du Search MOSS : Les scopes - Quelques possibilités d'amélioration du Search
Lorsqu'on installe le moteur de recherche de MOSS et qu'on le configure basiquement, on veut ...
SharePoint - Lister les templates utilisés - Identifier les définitions utilisées par vos sites
Un site SharePoint est créé à partir d'un modèle ou définition de site. Mais comment savoir après ...
PowerShell - Profile avec la participation de mon ami Tigrou :)
Adobe - Lancement de la CS4, tous à vos agendas !
[MAJ] PHP - Fonctions de redimensionnement d'images - BD : redimensionner image + picto après upload
Ajout de FONCTIONS de redimensionnement.
PHP - Tchat PHP V2.1 sans base de donnée
SharePoint et les statistiques d'utilisation - Comment obtenir des statistiques depuis SharePoint
La mise en place de ferme SharePoint doit s'accompagner d'une notion de gouvernance. Cette notion ...
Adobe - Nouvelles annonces Adobe sur le salon IBC 2008
PHP - PHP TV emission 2 (septembre 2008)
PHP - PDO ADMIN
[MAJ] Inscription contrôlée à une NewsLetter ou Service - Abonnement avec confirmation et désabonnement
Correction d'un point-virgule manquant (merci de m'avoir obligé à chercher JPierre) dans le module ...
PHP - Premier lundi d'une semaine et d'une année
JavaScript - Premier lundi d'une semaine et d'une année
ASP - Premier lundi d'une semaine et d'une année
Alphabet Radio et Code Morse - Alpha Zulu appelle Tango Charlie !
Encoder-Décoder en "Alphabet Radio" ... "Alpha Zulu appelle Tango Charlie !" ou en Code Morse ... ...
Filtrer les modèles de site SharePoint - Filtrer l'affichage des modèles de site SharePoint
Je vous propose de découvrir à l'aide de cet article quels mécanismes peuvent vous permettent de ...
ASP/PHP - Méthode de cryptage - par table de correspondance
(ASP/PHP) Une méthode de cryptage de données par l'utilisation d'une "table de correspondance ...
PHP - Listes liées (1 table) - version2
JavaScript - Rendre Visible ou Invisible des éléments d'un form
PHP - Listes liées (1 table) - version1
JavaScript - Intercepter le click sur vidéo WMP ou flash SWF
[MAJ] Une base de données sans base de données - Comment travailler avec des fichiers texte ?
Modification du paramétrage du dossier à scanner dans le popup qui permet de sélectionner l'image.
Jeux de l'été (et de 5) - Un jeu de Motus (mots de 8 lettres)
C'est reparti pour un tour... Comme je venais de proposer un jeu de Mastermind, je me suis dit que, ...
PowerShell - Extraire toutes les collections SharePoint en CSV
PowerShell - Lister les collections pour une WebApp SharePoint
PowerShell - Lister les utilisateurs d'un site SharePoint
PowerShell - Connaître le code version de votre SharePoint
Connaître la version de SharePoint installée - Comment savoir la version de SharePoint en cours
Dans le cadre de la maintenance de plusieurs fermes SharePoint, il est indispensable de connaître ...
PowerShell - Travailler avec une base de données SQL Server
.NET - Visual Studio 2008 sur Facebook : çà rock's
PowerShell - Ajouter des liens sur deux niveaux dans SharePoint
Un petit annuaire perso avec photo - en PHP et MySQL
Avoir des copains et des amis c'est bien que dis-je c'est même vital pour le bien être de chacun. ...
Une base de données sans base de données - Comment travailler avec des fichiers texte ?
Suite à une question sur le forum (les habitués me connaissent), je propose une mini-gestion de ...
ASP/PHP : Affichage de données en tableau html - Afficher des données (BD, Array) dans un tableau
Création d'un tableau "à la volée" pour afficher ses données. Affichage "en ligne" ou "en ...
PowerShell - Ajouter une liste dans un site SharePoint
Annuaire d'entreprise en PHP - Très pratique pour ne plus rien perdre
Mon petit annuaire d'entreprise, je m'en sers tous les jours alors autant vous en faire profiter. ...
PHP-MySQL : Formulaire - pour le script 'Bon anniversaire' de DB77
Formulaire et script d'enregistrement pour le script « Bon anniversaire » de DB77 en PHP/MySQL ...
.NET - Introducing Microsoft Silverlight 2.0, 2nd Edition
PHP5 - Upload de fichiers - Classe PHP
PHP - PHP 5 /MYSQL® 5
Tutorial : HTML | Scripting | ASP-PHP | ASP.net | SQL Server | XML
Sharepoint | XAML | Pocket | Dreamweaver | VML | Divers
  Scripts : Scripting | ASP-PHP | ASP.net | Divers
  Boutique | Annuaire | Bannières | Météo | Tribune | Partenariats
v3 © Didier 2003   
 

Corpo Sciences de Reims Partitions gratuites Carte, météo, annonces
 ASP-magazine Wygwam CodePPC DotNet Project TechNet Codes Sources MVP El Roubio Groupes Utilisateurs Microsoft The Inquirer FR