Integration de module c# COM+ pour IIS [Résolu]

Signaler
Messages postés
6
Date d'inscription
lundi 20 novembre 2006
Statut
Membre
Dernière intervention
16 août 2007
-
cs_DIDI75
Messages postés
6
Date d'inscription
lundi 20 novembre 2006
Statut
Membre
Dernière intervention
16 août 2007
-
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>

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

response.Write obj.writeHello
%>

</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!

2 réponses

Messages postés
3466
Date d'inscription
lundi 16 octobre 2000
Statut
Modérateur
Dernière intervention
30 octobre 2008
42
Salut,

meme remarque que l'autre post, a mettre dans les tutos

Mx
MVP C# 
Messages postés
6
Date d'inscription
lundi 20 novembre 2006
Statut
Membre
Dernière intervention
16 août 2007

ok