begin process at 2010 02 09 22:47:41
  Trouver un code source :
 
dans
 
Accueil > Forum > 

C#

 > 

Système

 > 

Autre

 > 

integration de module c# COM+ pour IIS


Derniers messages déposésPoser une question dans le forum ou lancer une discussion

integration de module c# COM+ pour IIS

jeudi 16 août 2007 à 15:43:57 | integration de module c# COM+ pour IIS

DIDI75



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!
jeudi 16 août 2007 à 17:42:27 | Re : integration de module c# COM+ pour IIS

MorpionMx

Membre Club Administrateur CodeS-SourceS
Réponse acceptée !
Salut,

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

Mx
MVP C#
 

jeudi 16 août 2007 à 17:44:59 | Re : integration de module c# COM+ pour IIS


Cette discussion est classée dans : fichier, projet, permet, assembly, monprojet


Répondre à ce message

Sujets en rapport avec ce message

Partage d'un fichier documentation entre plusieurs projets d'une même solution [ par staik ] Bonjour,Ma solution contient autant de projets que de niveaux applicatifs (framework, businessrules, web).Chaque classe et ses membres sont est bien c comment ajouter le fichier de config à mon projet de déploiement [ par siadlamri ] bonjour; mon programme C# (Windows forms) utilise un fichier de configuration contenant le nom de la base de donnée, car l'utilisateur de cette applic ajout fichier xml à la fin d'un autre fichier XML [ par zikofs ] salut tout le monde. j'ai un projet pu je drois ajouterle contenu d'un fichier XML à lafin d'un autre fichier XML. j'ai fait une interface ou je selec load projet [ par superismali ] Bonjour a tous,J'ai développé une petite application et j'ai enregistrer tous mes parametres dans un fichier xml. J'ai affecté a ce fichier de projet Fichier ressource dans le projet [ par Seth77 ] SalutApres avoir ajouter un nouveau fichier ressource dans le projet, comment fait on pour acceder aux informations qui y sont stocké ?Herve inclure un fichier au projet , comment pointer dessus [ par zncpo ] bonjour j'ai inclus au projet un fichier xlt(un modele excel) et j'aimerai savoir comment pointé dessus, c a dire que je veux ouvrir ce fichier(celui [Projet Déploiement]Tester existance d'un fichier [ par fcolo ] Bonjour,J'ai un projet de déploiement pour mon application qui fonctionne très bien.Maintenant, je m'attaque à m'en servir pour la mise à jours de l'a Configuration projet dll, comment y accéder ? [ par sphaxslayer ] Bonjour à tous,Voilà, j'ai un petit souci pour accéder à la configuration de ma dll. Voici un résumé de mes projets :D'abord, j'ai fait un projet dest réutilisation de classes dans C# [ par happyleptic ] Bonjour,Je suis un habitué du C++, je m'essaye à C# en .Net.J'arrive à faire des trucs de base, je ne trouve pas ça plus pratique que du C++/win32, ma Copier un fichier depuis ressource [ par kachoulbala ] Bonjour tout le monde, j'aimerai vous posez une question si vous savez m'aider.Mon probleme c'est que je n'arrive pas à copier un fichier *.ini (qui s


Nos sponsors


Sondage...

CalendriCode

Février 2010
LMMJVSD
1234567
891011121314
15161718192021
22232425262728

Consulter la suite du CalendriCode

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), 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

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,484 sec (4)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales