Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

  1. ###raw>post.musername###
    Candidat au Club
    Utilisation de constructeur avec le System.Reflection
    Bonjour,
    J'utilise le système de reflection afin de charger un dll, plus précisement le dll "MySql.Data.dll" de "MySQL V8".
    Cependant, il est nécessaire de créer une connexion MySqlConnection, dont on retrouve la documentation ici : https://dev.mysql.com/doc/dev/connec...Connection.htm
    Mais j'ai bien l'impression de ne pas pouvoir utiliser le constructeur afin de définir la "connection string" nécessaire a créer un lien avec la base de données.
    Voici ce que j'ai fait pour le moment.
    Code :Sélectionner tout -Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
     
    Assembly^ MySQLInterface = Assembly::LoadFile("C:\\Users\\Xabi\\source\\repos\\Bdd Benchmark\\data\\MySQL V8\\MySql.Data.dll");
    			if (MySQLInterface != nullptr)
    			{
    				MessageBox::Show("Ca charge le fichier");
     
    				if (auto typeConnection = MySQLInterface->GetType("MySql.Data.MySqlClient.MySqlConnection"))
    				{
    					MessageBox::Show("Ca trouve bien la classe");
    					if (Object^ instanceConnection = Activator::CreateInstance(typeConnection))
    					{
    						MessageBox::Show("Ca créée l'instance");
     
    						if (auto methodMySQLConnection = typeConnection->GetMethod("MySqlConnection")) {
    							MessageBox::Show("Ca charge la methode MySqlConnection");
    							try
    							{
    								MessageBox::Show(methodMySQLConnection->Invoke(instanceConnection, gcnew array<Object^>(1) {
    									"SERVER=" + this->adresse +
    									";DATABASE=" + this->dataBaseName +
    									";UID=" + this->login +
    									";PASSWORD=" + this->mdp + ";"
    								})->ToString());
    							}
    							catch (Exception^ e)
    							{
    								MessageBox::Show(e->ToString());
    							}
     
    						}
    						if (auto connectionOpenMethod = typeConnection->GetMethod("Open")) {
    							MessageBox::Show("Ca charge la methode Open");
    							try
    							{
    								MessageBox::Show(connectionOpenMethod->Invoke(instanceConnection, nullptr)->ToString());
    							}
    							catch (Exception^ e)
    							{
    								MessageBox::Show(e->ToString());
    							}
    						}
     
    					}
    				}
    			}

    Si vous aviez des solutions, je suis toute ouie.
    Merci
      0  0

  2. #2
    Expert éminent sénior
    Activator::CreateInstance() possède une surcharge qui accepte un tableau variadic de paramètres (déclaré params object[] en C#) en plus du type.
    De plus, il est possible que tu te compliques la vie pour rien en continuant à utiliser la réflexion: Si MySqlConnection implémente l'interface System:<img src="images/smilies/icon_biggrin.gif" border="0" alt="" title=":D" class="inlineimg" />ata::IDbConnection, alors tu peux l'utiliser directement...
    Code :Sélectionner tout -Visualiser dans une fenêtre à part
    if (auto instanceConnection = safe_cast<IDbConnection^>(Activator::CreateInstance(typeConnection, connectionString)) != nullptr)
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

###raw>template_hook.ano_emploi###