Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

MODULE C# COM+ POUR IIS


Information sur le tutorial

Catégorie :Tutoriaux Tutorial .NET ( DotNet ) Date de création : 16/08/2007 17:49:55 Vu : 3 320 fois

Note :
Aucune note

Commentaire sur cette source (0)
Ajouter un commentaire et/ou une note

Description

Comment accéder à une DLL installée sur un serveur IIS? en utilaisant un objet COM+ et une interface ASP

Tutorial

Intégration de module C# COM+ pour IIS -
 Pour integrer un module COM+ , il faut
1. Créer un projet de bibliothèque de classes publiques. remarque: le nom de la bibliothèque de classe doit correspondre au nom de l?espace de nom du projet.
2. Configurer l'Assembly : [i]générér les clefs avec le sn.exe[/i]- il s'agit de modifier ou ajouter des attributs dans le fichier AssemblyInfo.cs de votre projet.
- l'attribut le plus important est AssemblyKeyFile il s'agit de signer l'Assembly. c'est obligatoire.
La signature de l?Assembly permet de garantir l?authenticité du contenu de l'Assembly et que ce contenu n?a pas été modifié après que l?Assembly est été signé.
Pour ce faire, le SDK du framework.net possède un utilitaire sn.exe qui génère une paire de clef publique et privé permettant de signer votre Assembly.

? Ecrire la paire de clefs dans le binDebug du projet
A l'aide l'invite de commande dans le répertoire de votre projet , dans le binDébug écrire la commande suivant:
sn -k Monprojet.key
Elle permet d?écrire la paire de clef dans Monprojet.key.
Un fichier .key est crée et contient deux clefs privés et publics. La cléf privée signe l'Assembly et doit rester secrète.

sn = Strong Name Utility
k = génère une nouvelle paire de clef et l'ecrit dans le fichier de sortie ex: Monprojet.key

? Signer l?Assembly
Pour signer l'Assembly il faut
o Ecrire ceci [assembly: AssemblyKeyFile("Monprojet.key")] dans le fichier assembly. Il faut donner le chemin de génération exacte de la clef. Ici il est dans le répertoire bin

On obtient un Assembly COM+ signé.


3. ?Générer un GUID . GUID (Global Unique Identifier) qui est un nombre unique de 120 bits affecté à un objet lors de sa création.
Il est utilisé pour identifier la dll ou chaque composant dans la base de registre :
i. Pour générer un GUID aller dans le menu outils/create guid
ii. Dans le fichier AssemblyInfo.cs, faire clic droit + coller. On obtient l?identifiant unique.
iii. Ecrire le GUID sous ce format :
[assembly: Guid("7444A8B9-4F4F-4703-B300-73826D83EE17")]
Donne une clef pour l'installation dans le registre

4. Il ne faut pas oublier la publication pour COM Interop:
dans propriété du projet choisir "Propriétés de configuration/ inscrire pour COM Interop" = true qui permet de générer les fichier type TLB qui génére une biliothèque des types défini dans l'assembly.

5 Et compiler.

6. Inscrire l'Assembly dans le registre du systeme
dans le binDébug de votre projet executer la commande suivante :
regasm Monprojet.dll /tlb :Monprojet.tlb /verbose
nom de l'Assembly à écrire avec com = Monprojet.dll.
on obtient les messages suivants si commande réussi :
« les types sont enregistrés
le type de la classe publique créé dans le projet est exporté.
Assembly exporté dans Monprojet.tlb et le type library est enregistré. »
et dans bindebug : les fichiers .dll et .pdb.

Le regasm lit les métadonnées cad informations descriptives des Types et Classes publiques. Il permet d?inscrire l?Assembly et les classes concernées au registre ce qui permet à l?objet COM de créer des instances des classes figurant dans l?assembly en toute transparence
/tlb [:typeLibFile] Génère, à partir de l'assembly spécifié, une bibliothèque de types comportant les définitions des types accessibles définis dans l'assembly.
/verbose Spécifie le mode documenté ; affiche la liste de tous les assemblys référencés pour lesquels une bibliothèque de types doit être générée, en cas de spécification avec l'option /tlb.



EXEMPLE: Créer une interfaceclient sous ASP pour appeler le COM+

Classe publique:
using System;
using System.IO;


namespace biblio
{
/// <summary>
/// Description résumée de Class1.
/// </summary>
public class Classxml
{

public Classxml()//Constructeur
{
//
// TODO : ajoutez ici la logique du constructeur
//
}
public string writeHello()// Méthode publique
{
return("XMLExplore: Hello world 01");
}



~Classxml() // destructor
{

}
}
}

Page asp:
<%@ Language=VBScript %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<head>
<title></title>
<meta name="GENERATOR" content="Microsoft Visual Studio .NET 7.1">
<meta name="vs_targetSchema" content="http://schemas.microsoft.com/intellisense/ie5">
</head>
<body>

<%
dim obj
set obj=CreateObject("biblio.Classxml")

response.Write obj.writeHello
%>


</body>
</html>

Fichier AssemblyInfo.cs
using System.Reflection;
using System.Runtime.CompilerServices;
using System.Runtime.InteropServices;


//
// Les informations générales relatives à un assembly dépendent de
// l'ensemble d'attributs suivant. Pour modifier les informations
// associées à un assembly, changez les valeurs de ces attributs.
//
[assembly: AssemblyTitle("")]
[assembly: AssemblyDescription("")]
[assembly: AssemblyConfiguration("")]
[assembly: AssemblyCompany("")]
[assembly: AssemblyProduct("")]
[assembly: AssemblyCopyright("")]
[assembly: AssemblyTrademark("")]
[assembly: AssemblyCulture("")]

//
// Les informations de version pour un assembly se composent des quatre valeurs suivantes :
//
// Version principale
// Version secondaire
// Numéro de build
// Révision
[assembly: AssemblyKeyFile("biblio.key")]
// Vous pouvez spécifier toutes les valeurs ou indiquer des numéros de révision et de build par défaut
// en utilisant '*', comme ci-dessous :

[assembly: AssemblyVersion("1.2.*")]

//{994F4F21-0583-4302-A55F-6D82F2A8000C}

[assembly: Guid("994F4F21-0583-4302-A55F-6D82F2A8000C")]
//
// Pour signer votre assembly, vous devez spécifier la clé à utiliser. Consultez
// la documentation Microsoft .NET Framework pour plus d'informations sur la signature d'un assembly.
//
// Utilisez les attributs ci-dessous pour contrôler la clé utilisée lors de la signature.
//
// Remarques :
// (*) Si aucune clé n'est spécifiée, l'assembly n'est pas signé.
// (*) KeyName fait référence à une clé installée dans le fournisseur de
// services cryptographiques (CSP) de votre ordinateur. KeyFile fait référence à un fichier qui contient
// une clé.
// (*) Si les valeurs de KeyFile et de KeyName sont spécifiées, le
// traitement suivant se produit :
// (1) Si KeyName se trouve dans le CSP, la clé est utilisée.
// (2) Si KeyName n'existe pas mais que KeyFile existe, la clé
// de KeyFile est installée dans le CSP et utilisée.
// (*) Pour créer KeyFile, vous pouvez utiliser l'utilitaire sn.exe (Strong Name, Nom fort).
// Lors de la spécification de KeyFile, son emplacement doit être
// relatif au répertoire de sortie du projet qui est
// %Project Directory%obj<configuration>. Par exemple, si votre KeyFile se trouve
// dans le répertoire du projet, vous devez spécifier l'attribut
// AssemblyKeyFile sous la forme [assembly: AssemblyKeyFile("....mykey.snk")]
// (*) DelaySign (signature différée) est une option avancée. Pour plus d'informations, consultez la
// documentation Microsoft .NET Framework.
//
[assembly: AssemblyDelaySign(false)]

[assembly: AssemblyKeyName("")]


génére un composant binaire qui ne peut être copier.
on obtient un composant serveur qui permet de faire le lien entre le serveur IIS et une DLL; cet outil de communication permet d'accéder à une DLL installée sur un serveur IIS. la paire de clef permet d'authentifier l'origine du contenu de l'assembly et certifié que le contenu de l'assembly n'a pas été corrompu.


MERCI DE ME DONNER VOS AVIS ET REMARQUES!
Aucun commentaire pour le moment.

Ajouter un commentaire



Nos sponsors

Sondage...

CalendriCode

Novembre 2008
LMMJVSD
     12
3456789
10111213141516
17181920212223
24252627282930

Consulter la suite du CalendriCode



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel BAÏSE, Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,031 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.