begin process at 2012 05 28 19:25:43
  Trouver un code source :
 
dans
 
Accueil > Forum > 

C

 > 

Windows

 > 

System

 > 

DDK et service.


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

DDK et service.

vendredi 5 octobre 2007 à 17:03:33 | DDK et service.

deck_bsd

Membre Club
Yop à tous,


Voila je travail sur un service que j'avais codé sous XP et qui fait un acces à la registry avec les API Reg... et qui biensur ne fonctionne pas sous vista, la registry étant protégée. Donc je me suis dit , comme un service est un programme système, je doit pouvoir utiliser les fonctions du DDK. J'ai donc trouver : ZwOpenKey() et ZwQueryValueKey .

Seulement je ne comprend pas très bien leur utilisation. Car de 1 ZwOpenKey renvoie un pointeur sur HANDLE, est-ce l'équivalent à HKEY ? et puis il y à aussi le dernier paramètre de cette fonction , un pointeur sur une structure OBJET_ATTRIBUTES qui me parait vague.

Et pour la deuxième fonction, moi je veu simplement récuperer la valeur de ma key , mais aparament, je suis obligé de récuperer plus d'informations et vu les champs de la structure. Enfin bref , je ne sais pas trop, c'est fonctions me paraissent fort vague comparé aux API du SDK.

Est-ce que quelqu'un pourrait me montrer un exemple ou autre ? car là je sèche.

Merci d'avance.
++
deck_bsd
___________________________________
[ [ Lien ]]
vendredi 5 octobre 2007 à 19:26:20 | Re : DDK et service.

vicenzo

Membre Club
Si les API de registre ne fonctionnait plus sous Vista... plus aucune prog ne pourrais y ecrire et donc le registre ne servirait à plus rien.....

Je n'ai aucun souci à lire / ecrire dans le registre sous vista... toutes mes applis et services qui en ont besoin fonctionnent parfaitement.... Le souci ne viendrait il pas de ton code ? Tu veux y faire quoi comme manip dans le registre ?
vendredi 5 octobre 2007 à 21:21:44 | Re : DDK et service.

racpp

Administrateur CodeS-SourceS
Salut,
Les services standard fonctionnent en user-mode. Les pilotes sont des services qui fonctionnent en kernel-mode. C'est un monde à part. Donc tu ne devrais pas avoir besoin des fonctions du kernel-mode dans ton service. Les APIs du user-mode devraient suffire.
Le problème d'accès à la base de registre se pose en général depuis un compte non-administrateur. Il est possible que ce soit ton cas.
ZwOpenKey() et les autres sont normalement faites pour être appelées en kernel-mode.

vendredi 5 octobre 2007 à 23:19:36 | Re : DDK et service.

BruNews

Administrateur CodeS-SourceS
Bien qu'il soit possible d'utiliser ZwOpenKey() et autres, tout à fait d'accord avec racpp pour dire qu'il vaut mieux utiliser les fonctions user mode depuis ton service.

Problème pouvant subvenir sur Vista avec un service SYSTEM:
le service peut très bien être lancé par le chargeur alors que, par exemple, la ruche HKLM n'est pas encore dispo. Si tu dois y accéder et que RegOpenKeyEx retourne une erreur, prévoir une nouvelle tentative avec délai.

ciao...
BruNews, MVP VC++
samedi 6 octobre 2007 à 12:45:57 | Re : DDK et service.

deck_bsd

Membre Club
Oui justement, je sais que c'est parce que je suis en utilisateur standart que cela fait ça. Car de toute façons, sous vista, tout les utilisateur sont à la base standart. Il n'y à que quand on élève les privilège qu'on à un jeton admin. Donc les programme avec les API Reg... fonctionne très bien lorsque l'on fait "executé en tant qu'administrateur", mais voila, pour le service je n'ai aucun controle sur lui, donc je ne peut pas lui demander lorsqu'il se lance de s'éxécuter en admin, car justement le but de mon service est qu'il tourne tt seul sans personne :D . Donc voila je suis un peu piégé, j'ai bien penser à CreateProcessAsUser() mais dans un des param si je me souvient bien, on demande un handle token et lorsque l'on va voir la fonction qui permet de l'obtenir, celle-ci demande mot de passe et domaine, ce qui n'est pas portable car mon service doit être dispo pour qui le veut. Donc voila , je me trouve façe à un dilem.


++
deck_bsd
___________________________________
[ [ Lien ]]
samedi 6 octobre 2007 à 13:26:45 | Re : DDK et service.

BruNews

Administrateur CodeS-SourceS
En service SYSTEM (et non local), il doit pouvoir accéder à la BDR sans droits à demander.

ciao...
BruNews, MVP VC++
samedi 6 octobre 2007 à 13:30:29 | Re : DDK et service.

deck_bsd

Membre Club
En service systeme , oui , mais je ne sais par où commencer, je ne voi pas vraiment ce que je doit modifier pour en faire un service system :s Je sais, je suis plutot novice là dedans :s

++
deck_bsd
___________________________________
[ [ Lien ]]
samedi 6 octobre 2007 à 13:40:45 | Re : DDK et service.

BruNews

Administrateur CodeS-SourceS
Rien de bien particulier.
Va par contre lire "Service Changes for Windows Vista" dans MSDN.

ciao...
BruNews, MVP VC++
samedi 6 octobre 2007 à 14:48:19 | Re : DDK et service.

deck_bsd

Membre Club
Merci, je suis en train de lire l'article et pour le moment, pas grand chose pouvant m'aider.

Rien de bien particulier ? ben il y à quand mm bien quelque chose à modifier pour dire au système de l'éxécuter en tant que service system et non local :s


++
deck_bsd
___________________________________
[ [ Lien ]]
samedi 6 octobre 2007 à 15:01:31 | Re : DDK et service.

BruNews

Administrateur CodeS-SourceS
oh mais ça c'est juste le CreateSerrvice() du setup qui change.

ciao...
BruNews, MVP VC++

1 2 3

Cette discussion est classée dans : service, api, fonctions, ddk, registry


Répondre à ce message

Sujets en rapport avec ce message

C - WIN32 API - [ par philip63 ] Bonjour,Mon service tourne sousW2k en Local System; il est non-interactif (Service-0x0-3e7$\Default). Aprés avoir testé l'absence du Shell par defaut API pour les IT [ par superteta2003 ] Je voudrais trouver l'équivalent des fonction interrupt(), getvect(), setvect() de borlan turbo C. Ces fonctions sont inlus dans la librairie dos.h . API Win32 [ par bluewizard ] Bonjour tout le monde,j'aimerai savoir si il est possible de trouver une doc de la bibliothèque API Win32 en français avec toutes les fonctions sans e DDK : Comment utiliser les fonctions windows [ par Booster ] Bonjour à tous,Alors voilà, c'est mes premiers pas dans le développement de drivers.J'essaie de hooker createfile (J'ai trouvé des exemples) donc j'y Compatibilité allegro-windows : les fonctions le l'API win32 [ par programmateur ] (Je reposte ce message à cause de problemes de connexion au cite qui m'empechent de repondre a la discution)Salut,Je poste simplement ce message pour fonctions api win32 [ par mdgtr ] salutje voudrais obtenir de l'aide apropos d'une source en c++ qui aura comme tache de commander le windows media player a partir d'une fentre mais en compatibilité allegro-windows : les fonctions de l'API win32 [ par programmateur ] Salut,Je poste simplement ce message pour aider une quelconque personne qui rencontrerait le meme probleme que moi en utilisant les fonctions de l'API pb avec les fct API d'acces au registre en mode utilisateur avec pouvoir sous 2000 [ par Canth ] Si on est en utilisateur avec pouvoir sous Windows 2000/XP on ne peut pas lire et écrire dans la base des registres avec les fonctions de l'API sous l Adresse IP [ par Tribute2U ] Bjr, je cherche a utiliser un controle du style 'IP Address' et j'aurai voulu savoir comment marchait les fonctions GetAddress et SetAddress de la cla WSAAsyncSelect ... [ par DeAtHCrAsH ] A quel endroit dans mon code dois-je appeller cette fonction ?...WSAAsyncSelect(m_Socket, hDlg, WM_SOCKET, FD_READ | FD_WRITE | FD_CONNECT | FD_CLOSE)


Nos sponsors


Sondage...

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

A découvrir



 
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 : 8,861 sec (3)

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