IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
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

API, COM et SDKs Delphi Discussion :

Appel d'une DLL Delphi en C#


Sujet :

API, COM et SDKs Delphi

  1. #1
    Membre confirmé
    Homme Profil pro
    Chef de projets
    Inscrit en
    Août 2008
    Messages
    127
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Chef de projets
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2008
    Messages : 127
    Par défaut Appel d'une DLL Delphi en C#
    Bonjour,

    J'ai travaillé sur l'appel d'une dll Delphi en C#.
    J'arrive à faire quelques manipulations (afficher un texte, écrire dans un fichier, ....).

    Mon souci est le suivant :
    Je n'arrive pas à ouvrir une base de données depuis la dll.
    J'appelle la même dll depuis un exe Delphi ca marche....

    Voici l'appel en C#
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    [DllImport("YMsSqlDbUpdate.dll", CharSet = CharSet.Ansi, CallingConvention = CallingConvention.StdCall)]
            static extern int yConnectedDatabase();
     
            static public void MainUpdate()
            {
                yConnectedDatabase();
            }
    Et voilà le code en Delphi 7
    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
     
    procedure yConnectedDatabase; StdCall;
    begin
        fMsSqlDbUpdate.yConnectedByDLL;
    end;
     
    procedure TfMsSqlDbUpdate.yConnectedByDLL;
    var
        cnx : TYSqlConnection;
    begin
        try
           cnx := TYSqlConnection.Create(nil);
          cnx.Connected      := false;
          cnx.ConnectionName := 'SQLServerConnection';
          cnx.DriverName     := 'SQLServer';
          cnx.GetDriverFunc  := 'getSQLDriverSQLServer';
          cnx.KeepConnection := true;
          cnx.LoginPrompt    := false;
          cnx.LibraryName    := 'dbexpsda.dll';
          cnx.VendorLib      := 'sqloledb.dll';
     
          cnx.Params.Values['DriverName']  := 'SQLServer';
          cnx.Params.Values['HostName']    := 'MyServer';
          cnx.Params.Values['DataBase']    := 'MyBDD';
          cnx.Params.Values['User_Name']   := 'USER';
          cnx.Params.Values['Password']    := '1';
     
          cnx.Params.Values['BlobSize']    := '-1';
          cnx.Params.Values['LongStrings'] := 'True';
          cnx.Params.Values['EnableBCD']   := 'False';
          cnx.Params.Values['FetchAll']    := 'True';
     
          try
             cnx.Connected := true;
            except
              on e:Exception do
                 DebugSource('c:\tltl.txt', e.Message);
          end;
       finally
            DetruitObjet(cnx);
       end;
    end;
    Voila, merci pour votre aide.

  2. #2
    Expert éminent
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    14 071
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 14 071
    Par défaut
    TfMsSqlDbUpdate est-ce une form ?
    Si oui, est-elle instanciée ?
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

  3. #3
    Membre confirmé
    Homme Profil pro
    Chef de projets
    Inscrit en
    Août 2008
    Messages
    127
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Chef de projets
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2008
    Messages : 127
    Par défaut
    Oui TfMsSqlDbUpdate est une forme qui est instanciée. J'ai racourci un peu le code.
    Il ne faut pas perdre de vu, que si j'appelle m'a dll depuis un exe Delphi, la dll fonctionne.

  4. #4
    Membre Expert Avatar de guillemouze
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    876
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Novembre 2004
    Messages : 876
    Par défaut
    a tout hasard, ca viendrai pas de ta declaration, du genre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    static extern void yConnectedDatabase();

  5. #5
    Membre confirmé
    Homme Profil pro
    Chef de projets
    Inscrit en
    Août 2008
    Messages
    127
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Chef de projets
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2008
    Messages : 127
    Par défaut
    Bon ben j'ai résolu mon problème....

    En fait ça ne venait ni du code Delphi ni du code C#, mais une dll d'accès aux données coté Delphi qui ne permettait pas l'ouverture de base dans un contexte d'appel de la dll depuis C#

    Il faut donc la dll : dbexpsda.dll en version 4.25.0.10

    Merci pour votre aide

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Appel d'une DLL écrite en C# en Delphi
    Par develpp1 dans le forum Débuter
    Réponses: 5
    Dernier message: 18/06/2012, 16h01
  2. Réponses: 17
    Dernier message: 27/04/2007, 11h06
  3. Réponses: 1
    Dernier message: 11/04/2007, 11h45
  4. Appel d'une DLL en delphi en VB.net
    Par pytpyt dans le forum Windows Forms
    Réponses: 1
    Dernier message: 11/04/2007, 11h43
  5. Réponses: 4
    Dernier message: 01/06/2006, 15h55

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo