begin process at 2008 07 06 01:27:16
1 205 425 membres
7 nouveaux aujourd'hui
14 119 membres club

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 !

APPELER FONCTION D'UN EXE A PARTIR DES PARAMÈTRE ENTRER PAR L'UTILISATEUR


Information sur la source

Catégorie :API Classé sous : fonction, exe, paramètre Niveau : Débutant Date de création : 24/09/2005 Date de mise à jour : 25/09/2005 22:58:10 Vu / téléchargé: 4 909 / 197

Note :
6,2 / 10 - par 5 personnes
6,20 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

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

Description

Vous pouvez maintenant appeler une fonction d'une dll en "ligne de commande".
Permets donc à l'utilisateur de pouvoir appeler, avec les paramètres qu'il aura choisis, d'appeler le pointeur d'une dll.

2 exemples sont dans la source.
Note: vous devez quand même respecter le nombre de paramètres du pointeur

Dll(...) : appelés le pointeur, les paramètres sont directement dans Dll().
Ex: dll("dll.dll","CallFuncExe","Ceci est le premier paramètre","2e paramètre","et on peut en mettre autant qu'on veut");

le 2e exemple se rapproche de la "ligne de commande".
Il utilise une seule variable char * le découpe en X paramètres avec Dll2();
char paramètre_dans_char[]="Ceci est le premier paramètre,2e paramètre,et on peut en mettre autant qu'on veut";
Dll2("dll.dll","CallFuncExe",paramètre_dans_char);

Pour le nom du fichier et le nom de la fonction il n'est pas très difficile de le demander a l'utilisateur donc je n'est pas plus compliqué la source.

Source

  • #include <stdio.h>
  • #include <windows.h>
  • typedef void(*DLL_CALLEXE)(...);
  • // Équivalent de strtok mais qui retourne un tableau
  • // Retourne le nombre de token (ATTENTION, le nombre 0 compte pour un, donc si il retourne 1 il y a 2 tableau)
  • int motparmot(char *** output,char * input,int chart){
  • int mots=0;
  • int lettre=0;
  • output[0]=(char**)malloc(1);
  • output[0][0]=NULL;
  • for(int i=0;i<=(int)strlen(input);i++){
  • output[0][mots]=(char*)realloc(output[0][mots],lettre+1);
  • if(i==strlen(input)) {
  • output[0][mots][lettre]='\0';
  • return mots;
  • }else if(input[i]==chart){
  • output[0][mots][lettre]='\0';
  • // Note: le lettre++ plus bas va le remetre à 0
  • lettre=-1;
  • mots++;
  • output[0][mots]=NULL;
  • }else output[0][mots][lettre]=input[i];
  • lettre++;
  • }
  • return -1;
  • }
  • // Fonction qui charge le pointeur
  • DLL_CALLEXE dll_loadfunc(char * filename,char * fonctionname){
  • HMODULE DLL = LoadLibrary(filename);
  • // L'erreur la plus courante retourné est "fichier non trouvé"
  • if(!DLL) return (DLL_CALLEXE)-1;
  • else {
  • DLL_CALLEXE FonctionDll;
  • // Charge l'adresse de la fonction CallFuncExe dans le DLL (pointeur)
  • FonctionDll = (DLL_CALLEXE)GetProcAddress(DLL,fonctionname);
  • if(!FonctionDll){ FreeLibrary(DLL); return (DLL_CALLEXE)-2; }
  • return FonctionDll;
  • }
  • }
  • // Fonctoin qui apelle le pointeur (merci à edcba du réseau EpikNet)
  • int calldll(int nbparam,void ** params,void * TmpFonction){
  • int retvalue;
  • _asm {
  • mov ecx,nbparam
  • mov ebx,params
  • dec ecx
  • js appel
  • boucle:
  • push [ebx+ecx*4]
  • dec ecx
  • jns boucle
  • appel:
  • call TmpFonction
  • mov retvalue,eax
  • }
  • return retvalue;
  • }
  • void dll(int num,char * filename,char * fonctionname,...){
  • // Charge le pointeur
  • DLL_CALLEXE TmpFonction=NULL;
  • TmpFonction=dll_loadfunc(filename,fonctionname);
  • if((int)TmpFonction<1) { MessageBox(0,"Impossible de charger la DLL","Erreur",0); exit((int)TmpFonction); }
  • // parti où on récupère les paramètres non fixe (les ... a la fin de la fonction)
  • // Un exemple : printf(), vous pouvez mettre autant de paramètre que voulu
  • va_list marker;
  • va_start(marker,num);
  • va_arg(marker,char*);
  • va_arg(marker,char*);
  • // Prépare la liste des paramètres a envoyer au pointeur
  • void** params;
  • params=(void**)malloc(num*sizeof(void*));
  • for(int i=0; i < num;i++){
  • params[i]=va_arg(marker,void*);
  • }
  • va_end(marker);
  • // Appelle la fonction
  • calldll(num,params,TmpFonction);
  • }
  • void dll2(char * filename,char * fonctionname,char * params,int chars){
  • // Charge le pointeur
  • DLL_CALLEXE TmpFonction=NULL;
  • TmpFonction=dll_loadfunc(filename,fonctionname);
  • if((int)TmpFonction<1) { MessageBox(0,"Impossible de charger la DLL","Erreur",0); exit((int)TmpFonction); }
  • char ** token=NULL;
  • // va retourner dans un tableau les params
  • int nbtoken=motparmot(&token,params,chars)+1;
  • // Prépare la liste des paramètres a envoyer au pointeur
  • void ** paramsdll=(void**)malloc(nbtoken*sizeof(void*));
  • for(int i=0; i<nbtoken; i++){
  • paramsdll[i]=token[i];
  • }
  • // Appelle le pointeur
  • calldll(nbtoken,paramsdll,TmpFonction);
  • }
  • int main(){
  • // dll(nombre de paramètre,fichier dll, fonction,param...);
  • // Exemple #1
  • dll(2,"dll.dll","CallFuncExe","Un seul parametre","pour CallFuncExe");
  • // dll2(nom dll,fonction dll,variable des paramètres, caracthère séparant les paramètres);
  • // Exemple #2
  • char param[]="Un simple char,peut faire l'affaire !";
  • dll2("dll.dll","CallFuncExe",param,',');
  • system("pause");
  • return 1;
  • }
#include <stdio.h>
#include <windows.h>

typedef void(*DLL_CALLEXE)(...);

// Équivalent de strtok mais qui retourne un tableau
// Retourne le nombre de token (ATTENTION, le nombre 0 compte pour un, donc si il retourne 1 il y a 2 tableau)
int motparmot(char *** output,char * input,int chart){
	int mots=0;
	int lettre=0;
	output[0]=(char**)malloc(1);
	output[0][0]=NULL;
	for(int i=0;i<=(int)strlen(input);i++){
		output[0][mots]=(char*)realloc(output[0][mots],lettre+1);
		if(i==strlen(input)) {
			output[0][mots][lettre]='\0';
			return mots;
		}else if(input[i]==chart){
			output[0][mots][lettre]='\0';
			// Note: le lettre++ plus bas va le remetre à 0
			lettre=-1;
			mots++;
			output[0][mots]=NULL;
		}else output[0][mots][lettre]=input[i];
	lettre++;
	}
	return -1;
}

// Fonction qui charge le pointeur
DLL_CALLEXE dll_loadfunc(char * filename,char * fonctionname){
	HMODULE DLL = LoadLibrary(filename);
	// L'erreur la plus courante retourné est "fichier non trouvé"
	if(!DLL) return (DLL_CALLEXE)-1;
	else {
		DLL_CALLEXE FonctionDll;
		// Charge l'adresse de la fonction CallFuncExe dans le DLL (pointeur)
		FonctionDll = (DLL_CALLEXE)GetProcAddress(DLL,fonctionname);
		if(!FonctionDll){ FreeLibrary(DLL); return (DLL_CALLEXE)-2; }
		return FonctionDll;
	}

}

// Fonctoin qui apelle le pointeur (merci à edcba du réseau EpikNet)
int calldll(int nbparam,void ** params,void * TmpFonction){
	int retvalue;
	_asm { 
		 mov ecx,nbparam 
		 mov ebx,params 
		 dec ecx 
		 js appel 
	 boucle: 
		 push [ebx+ecx*4] 
		 dec ecx 
		 jns boucle 
	appel: 
		  call TmpFonction 
		  mov retvalue,eax 
	 } 
	return retvalue;
}

void dll(int num,char * filename,char * fonctionname,...){
	// Charge le pointeur
	DLL_CALLEXE TmpFonction=NULL;
		TmpFonction=dll_loadfunc(filename,fonctionname);
		if((int)TmpFonction<1)  { MessageBox(0,"Impossible de charger la DLL","Erreur",0); exit((int)TmpFonction); }

	// parti où on récupère les paramètres non fixe (les ... a la fin de la fonction)
	// Un exemple : printf(), vous pouvez mettre autant de paramètre que voulu
	va_list marker;
	va_start(marker,num);
	va_arg(marker,char*);
	va_arg(marker,char*);

	// Prépare la liste des paramètres a envoyer au pointeur
	void** params; 
	params=(void**)malloc(num*sizeof(void*));
	for(int i=0; i < num;i++){
		params[i]=va_arg(marker,void*);
	}

	va_end(marker);
	// Appelle la fonction
	calldll(num,params,TmpFonction);

}

void dll2(char * filename,char * fonctionname,char * params,int chars){
	// Charge le pointeur
	DLL_CALLEXE TmpFonction=NULL;
		TmpFonction=dll_loadfunc(filename,fonctionname);
		if((int)TmpFonction<1)  { MessageBox(0,"Impossible de charger la DLL","Erreur",0); exit((int)TmpFonction); }
		
		char ** token=NULL;
		// va retourner dans un tableau les params
		int nbtoken=motparmot(&token,params,chars)+1;

		// Prépare la liste des paramètres a envoyer au pointeur
		void ** paramsdll=(void**)malloc(nbtoken*sizeof(void*));
		for(int i=0; i<nbtoken; i++){
			paramsdll[i]=token[i];
		}
		// Appelle le pointeur
		calldll(nbtoken,paramsdll,TmpFonction);
}

int main(){
	// dll(nombre de paramètre,fichier dll, fonction,param...);
	// Exemple #1
	dll(2,"dll.dll","CallFuncExe","Un seul parametre","pour CallFuncExe");
	
	// dll2(nom dll,fonction dll,variable des paramètres, caracthère séparant les paramètres);
	// Exemple #2
	char param[]="Un simple char,peut faire l'affaire !";
	dll2("dll.dll","CallFuncExe",param,',');
	
	system("pause");
	return 1;
}

Conclusion

Merci encore à edcba sur le réseau Epiknet pour la parti en ASM.
Si quelqu'un a l'équivalent de la fonction calldll(...); version C/C++ je suis preneur
Pour les "Membres Club", vous pouvez télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip

24 septembre 2005 16:42:21 :
Effacer l'exemple de callback d'une fonction EXE a partir d'une DLL
24 septembre 2005 16:43:31 :
Faute légère
25 septembre 2005 22:58:10 :
Ajoute d'une 2e exemple (qui est l'équivalent de la "ligne de commande")
  • signaler à un administrateur
    Commentaire de Taron31 le 24/09/2005 16:29:48

    tu peux m'expliquer le principe de ton code stp :-)
    j'ai vu que tu chargeais une fonction dll, mais tu comptes faire quoi avec ta fonction FuncExe() ?

  • signaler à un administrateur
    Commentaire de Suisse00 le 24/09/2005 16:44:31

    La fonction FuncExe na pas vraiment rapport avec le sujet de ce code je l'est donc enlevez ;)

  • signaler à un administrateur
    Commentaire de Taron31 le 24/09/2005 21:07:46

    Ok, mais tu faisais quoi sinon avec cette fonction ?
    Tu l'exportais ?

  • signaler à un administrateur
    Commentaire de Zootella le 25/09/2005 18:56:10

    C'est pratique mais il manque quelque chose.

    Tu dis : "Permet d'appeler une fonction dll avec les paramètres entrer par l'utilisateur (donc "dynamique")."

    Mais dans ton exemple l'utilisateur c'est toi, et si quelqu'un voulait lancer une fonction qui prend 2, 3 ou 4 paramétres, il devra à chaque fois rajouter ces paramétres dans ta fonction dll(), puis recompiler.

    Par exemple faire un dialog avec 2 edits : 1 pour la fonction à lancer l'autre pour ses paramétres et un bouton lancer qui appelle la fonction avec les paramétres récupérés dans l'edit 2.

  • signaler à un administrateur
    Commentaire de lolont le 26/09/2005 08:24:33

    je n'ai pas encore essayé le code, mais si ça marche vraiment, c'est genial.
    je cherchais justement un truc de ce genre là .

  • signaler à un administrateur
    Commentaire de laurent4x4x le 13/06/2006 12:56:39

    HELP !!!
    Bonjour à toutes et à tous,
    ce code me semblait bien pratique pour que je puisse enfin mettre les deux pieds dans l'univers des manipulations de dlls qu'elles soient en c en vb ou en cpp
    MAIS : le projet pris tel que ouvert sous VS 2003 (version 7.1)NE COMPILE PAS !! j'ai bien essaye de voir ce que je pouvais faire tout seul mais je n'y arrive pas j'ai d'abord besoin d'un code qui fonctionne pour pouvoir acquérir des compétencxes , quelqu'un peu m'aider.
    voici  la sortie de visual studio
    ------ Début de la génération : Projet : dll, Configuration : Release Win32 ------

    Compilation...
    dll.cpp
    dll.cpp(18) : error C2065: 'DLL_CALLDLL' : identificateur non déclaré
    dll.cpp(18) : error C2146: erreur de syntaxe : absence de ';' avant l'identificateur 'FunctionExe'
    dll.cpp(18) : error C2065: 'FunctionExe' : identificateur non déclaré
    dll.cpp(18) : error C2146: erreur de syntaxe : absence de ';' avant l'identificateur 'GetProcAddress'
    dll.cpp(18) : error C3861: 'DLL_CALLDLL': identificateur introuvable, même avec une recherche qui dépend de l'argument
    dll.cpp(19) : error C3861: 'FunctionExe': identificateur introuvable, même avec une recherche qui dépend de l'argument

    Le journal de génération a été enregistré à l'emplacement "file://f:\ExtAlex\CodeC_et_cpp\dll en ligne de commande\cppfrance_source_33930\dll\Release\BuildLog.htm"
    dll - 6 erreur(s), 0 avertissement(s)


    ------ Début de la génération : Projet : exe, Configuration : Release Win32 ------

    Compilation...
    main.cpp
    main.cpp(23) : warning C4311: 'cast de type' : troncation de pointeur de 'DLL_CALLEXE' à 'int'
    main.cpp(23) : warning C4311: 'cast de type' : troncation de pointeur de 'DLL_CALLEXE' à 'int'
    Édition des liens en cours...

    Le journal de génération a été enregistré à l'emplacement "file://f:\ExtAlex\CodeC_et_cpp\dll en ligne de commande\cppfrance_source_33930\exe\Release\BuildLog.htm"
    exe - 0 erreur(s), 2 avertissement(s)


    ---------------------- Terminé ----------------------

        Génération : 1 a réussi, 1 a échoué, 0 a été ignoré


    Merci pour toute l'aide possible

Ajouter un commentaire

Pub



Appels d'offres

Plugin Dialer outlook
Budget : 2 000€
Travail graphique- ill...
Budget : 1 000€
creation de marque et ...
Budget : 1 000€

CalendriCode

Juillet 2008
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

VS Express FR Gratuit !

VS Express en français et 100% gratuit !

Téléchargements

Logiciels à télécharger sur le même thème :

Boutique

Boutique de goodies CodeS-SourceS