Accueil > > > SERVICE WINDOWS POUR MAINTENIR SA CONNEXION INTERNET
SERVICE WINDOWS POUR MAINTENIR SA CONNEXION INTERNET
Information sur la source
Description
Le but de ce programme était avant tout la création d'un service. La programmation d'un service windows offre de nombreux avantage sur un programme classique. En tant que service le programme se lance automatiquement et sans action de l'utilisateur il est parfaitement invisible pour l'utilisateur. Il ne necessite pas d'être loggué sur le poste pour s'executer. J'avais besoin d'avoir un programme très fiable et très légè et parfaitement invisible qui puisse tourner en permance même si l'ordinateur n'était pas logué sous windows, qui puisse faire certaine opération de façon cyclique. J'ai donc créé un service windows. Il est le fruit de mes recherches sur le net sur la programmation d'un service Le code que je vous livre peut facilement être modifié pour faire d'autres opérations avec tous les avantages d'avoir un programme qui tourne en tant que service windows. Ce code s'adresse à toutes les personnes qui disposent d'une connexion internet permante ou non et qui souhaite empècher celle ci d'être coupé au bout d'un certaint temps d'inactivité. Il provoque tous les x temps une connexion par le port 80 (HTTP) sur la page google, tout cela en arrière plant ss interaction avec l'utilisateur. Cela permet soit d'éviter les deconnexions intempestives de certains FAI, soit d'empecher l'expiration du bail internet sur un réseau d'entreprise où l'accès à l'exterieur hors du réseau local est soumis à authentification. pour installer le service : mettre l'exe ds le rep ou vous souhaitez qu'il s'execute ouvrez une fenetre DOS en suite ds la fenetre DOS taper CD "c:\chemin_jusqu'au_fichier" et pour finir connexion.exe -i pour l'installer pour le desinstaller meme chose mais avec le paramètre -d pour le supprimé
Source
- //Source developpé sous dev c++
-
-
- //---------------------------------------------------------------------------
-
- //Commande preprocesseur
-
- #include <stdio.h>
- #include <time.h> //Pour la fonction sleep
- #include <winsock2.h> //Pour le client winsock
-
-
-
- //Déclaration des variables
- SERVICE_STATUS m_ServiceStatus;
- SERVICE_STATUS_HANDLE m_ServiceStatusHandle;
- bool bRunning=true;
-
-
- //Déclaration des variable pour le client winsock
- SOCKET s;
- in_addr addr;
- sockaddr_in sin;
- hostent * host;
- WSADATA wsa;
- char buf[1024];
- int octet = 0;
-
-
- //Déclaration des fonctions
- void WINAPI ServiceMain(DWORD argc, LPTSTR *argv);
- void WINAPI ServiceCtrlHandler(DWORD Opcode);
- bool InstallService();
- bool DeleteService();
- int Action(void);
- //---------------------------------------------------------------------------
-
-
-
-
-
-
-
- //---------------------------------------------------------------------------
- //Fonction principal
- //Analyse des arguments passé en paramètre.
- //Si pas de paramètre passé en argument initialisation du service
-
- int main(int argc, char* argv[])
- {
- if(argc>1)
- {
- if(strcmp(argv[1],"-i")==0) //Control de l'argument passé au prog
- {InstallService();} //Rien lancement du service
- //-i pour enregistement du service
-
- if(strcmp(argv[1],"-d")==0) //-d pour désactivation du service
- {DeleteService();}
- }
- else
- {
- //Si pas d'argument :
- //déclaration du service et démarrage dans ServiceMain()
- SERVICE_TABLE_ENTRY DispatchTable[]={{"Connexion",ServiceMain},{NULL,NULL}};
- StartServiceCtrlDispatcher(DispatchTable);
- }
- return 0;
- }
- //---------------------------------------------------------------------------
-
-
-
-
-
-
-
- //---------------------------------------------------------------------------
- //Fontion principal où se situe le code que le service execute
-
- void WINAPI ServiceMain(DWORD argc, LPTSTR *argv)
- {
-
- //Déclaration des variables
- DWORD status;
- DWORD specificError;
-
- m_ServiceStatus.dwServiceType =SERVICE_WIN32;
- m_ServiceStatus.dwCurrentState = SERVICE_START_PENDING;
- m_ServiceStatus.dwControlsAccepted = SERVICE_ACCEPT_STOP;
- m_ServiceStatus.dwWin32ExitCode = 0;
- m_ServiceStatus.dwServiceSpecificExitCode = 0;
- m_ServiceStatus.dwCheckPoint = 0;
- m_ServiceStatus.dwWaitHint = 0;
-
- m_ServiceStatusHandle = RegisterServiceCtrlHandler("Connexion",ServiceCtrlHandler);
- if (m_ServiceStatusHandle == (SERVICE_STATUS_HANDLE)0)
- {
- return;
- }
-
- m_ServiceStatus.dwCurrentState = SERVICE_RUNNING;
- m_ServiceStatus.dwCheckPoint = 0;
- m_ServiceStatus.dwWaitHint = 0;
- if (!SetServiceStatus (m_ServiceStatusHandle, &m_ServiceStatus))
- {
-
- }
-
- bRunning=true;
-
- //C'est la qu'il faut mettre les commandes qui s'éxécuteront pendant tout le temps ou le service fontcionne
- while(bRunning)
- {
- //Commande que le service execute
- //les 4 ligne du dessous servent juste aà montrer que le service tourne et que tout les minutes il écrit test dans le fichier text
- FILE * log ;
- log = fopen ( "c:\\log.txt" , "a" ) ;
- fprintf ( log , "test\n" ) ;
- fclose ( log ) ;
- Sleep(6000); //Le temps est en millisseconde, sert à temporiser l'action pour pas quelle s'execute en boucle
- //on peut aussi avoir une action qui se déclanche sur un évènement partculié
- Action(); //Fonction où mettre le code a executer
- }
-
- return;
- }
-
-
- //---------------------------------------------------------------------------
- //Fonction de control de l'état du service
-
- void WINAPI ServiceCtrlHandler(DWORD Opcode)
- {
- switch(Opcode)
- {
- //Si le service reçoit la commande de se mettre en pause
- case SERVICE_CONTROL_PAUSE:
- m_ServiceStatus.dwCurrentState = SERVICE_PAUSED;
- break;
-
- case SERVICE_CONTROL_CONTINUE:
- m_ServiceStatus.dwCurrentState = SERVICE_RUNNING;
- break;
-
- //Si le service reçoit la commande de stopper
- case SERVICE_CONTROL_STOP:
- m_ServiceStatus.dwWin32ExitCode = 0;
- m_ServiceStatus.dwCurrentState = SERVICE_STOPPED;
- m_ServiceStatus.dwCheckPoint = 0;
- m_ServiceStatus.dwWaitHint = 0;
-
- SetServiceStatus (m_ServiceStatusHandle,&m_ServiceStatus);
- bRunning=false; //donc la boucle plus haut ne s'effectura plus
- break;
-
- case SERVICE_CONTROL_INTERROGATE:
- break;
- }
- return;
- }
-
-
- //---------------------------------------------------------------------------
- //Si l'argument est -i enregistement du service ici
-
- bool InstallService()
- {
-
- char strDir[1024];
- SC_HANDLE schSCManager,schService;
-
- GetCurrentDirectory(1024,strDir);
- strcat(strDir,"\\connexion.exe");
-
-
- schSCManager = OpenSCManager(NULL,NULL,SC_MANAGER_ALL_ACCESS);
-
- if (schSCManager == NULL)
- return false;
-
- LPCTSTR lpszBinaryPathName=strDir;
-
- schService = CreateService(schSCManager,"Connexion","Connexion réseaux",
- SERVICE_ALL_ACCESS, // Type d'acces
- SERVICE_WIN32_OWN_PROCESS, // Type de service
- SERVICE_AUTO_START, // Pour le demarrage automatique
- SERVICE_ERROR_NORMAL, // error control type
- lpszBinaryPathName, // service's binary
- NULL, // no load ordering group
- NULL, // no tag identifier
- NULL, // no dependencies
- NULL, // Si null demarrer en tant que compte system
- NULL); // Mot de passe : null si demarrer en tant que system
-
- if (schService == NULL)
- return false;
-
- CloseServiceHandle(schService);
-
- return true;
- }
-
-
- //---------------------------------------------------------------------------
- //Si l'argument est -d désactivation du service ici
-
- bool DeleteService()
- {
- SC_HANDLE schSCManager;
- SC_HANDLE hService;
-
- schSCManager = OpenSCManager(NULL,NULL,SC_MANAGER_ALL_ACCESS);
-
- if (schSCManager == NULL)
- return false;
-
- hService=OpenService(schSCManager,"Connexion",SERVICE_ALL_ACCESS);
-
- if (hService == NULL)
- return false;
-
- if(DeleteService(hService)==0)
- return false;
-
- if(CloseServiceHandle(hService)==0)
- return false;
- else
- return true;
- }
-
-
- //---------------------------------------------------------------------------
- //Fonction pour la connexion a internet
-
- int Action(void)
- {
- WSAStartup(0x0202, &wsa);
-
- s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
- /*if(s == SOCKET_ERROR){
- //printf("socket : %d\n", WSAGetLastError());
- }
- */
-
- host = gethostbyname("www.google.fr"); //l'adresse du site (necessite winsock2.h et ws2_32.lib)
-
- memcpy(&addr, host->h_addr, host->h_length);
- sin.sin_family = AF_INET;
- sin.sin_port = htons(80); // HTTP
- sin.sin_addr = addr;
-
- if(SOCKET_ERROR == connect(s,(sockaddr*)&sin, sizeof(sin))){
- //printf("connect : %d\n", WSAGetLastError());
- }
-
- strcpy(buf, "GET http://www.google.fr HTTP/1.0\n\n"); // la requete http
- send(s, buf, strlen(buf), 0);
-
- octet = recv(s, buf, sizeof(buf), 0);
-
-
- closesocket(s);
- WSACleanup();
- return 0;
- }
//Source developpé sous dev c++
//---------------------------------------------------------------------------
//Commande preprocesseur
#include <stdio.h>
#include <time.h> //Pour la fonction sleep
#include <winsock2.h> //Pour le client winsock
//Déclaration des variables
SERVICE_STATUS m_ServiceStatus;
SERVICE_STATUS_HANDLE m_ServiceStatusHandle;
bool bRunning=true;
//Déclaration des variable pour le client winsock
SOCKET s;
in_addr addr;
sockaddr_in sin;
hostent * host;
WSADATA wsa;
char buf[1024];
int octet = 0;
//Déclaration des fonctions
void WINAPI ServiceMain(DWORD argc, LPTSTR *argv);
void WINAPI ServiceCtrlHandler(DWORD Opcode);
bool InstallService();
bool DeleteService();
int Action(void);
//---------------------------------------------------------------------------
//---------------------------------------------------------------------------
//Fonction principal
//Analyse des arguments passé en paramètre.
//Si pas de paramètre passé en argument initialisation du service
int main(int argc, char* argv[])
{
if(argc>1)
{
if(strcmp(argv[1],"-i")==0) //Control de l'argument passé au prog
{InstallService();} //Rien lancement du service
//-i pour enregistement du service
if(strcmp(argv[1],"-d")==0) //-d pour désactivation du service
{DeleteService();}
}
else
{
//Si pas d'argument :
//déclaration du service et démarrage dans ServiceMain()
SERVICE_TABLE_ENTRY DispatchTable[]={{"Connexion",ServiceMain},{NULL,NULL}};
StartServiceCtrlDispatcher(DispatchTable);
}
return 0;
}
//---------------------------------------------------------------------------
//---------------------------------------------------------------------------
//Fontion principal où se situe le code que le service execute
void WINAPI ServiceMain(DWORD argc, LPTSTR *argv)
{
//Déclaration des variables
DWORD status;
DWORD specificError;
m_ServiceStatus.dwServiceType =SERVICE_WIN32;
m_ServiceStatus.dwCurrentState = SERVICE_START_PENDING;
m_ServiceStatus.dwControlsAccepted = SERVICE_ACCEPT_STOP;
m_ServiceStatus.dwWin32ExitCode = 0;
m_ServiceStatus.dwServiceSpecificExitCode = 0;
m_ServiceStatus.dwCheckPoint = 0;
m_ServiceStatus.dwWaitHint = 0;
m_ServiceStatusHandle = RegisterServiceCtrlHandler("Connexion",ServiceCtrlHandler);
if (m_ServiceStatusHandle == (SERVICE_STATUS_HANDLE)0)
{
return;
}
m_ServiceStatus.dwCurrentState = SERVICE_RUNNING;
m_ServiceStatus.dwCheckPoint = 0;
m_ServiceStatus.dwWaitHint = 0;
if (!SetServiceStatus (m_ServiceStatusHandle, &m_ServiceStatus))
{
}
bRunning=true;
//C'est la qu'il faut mettre les commandes qui s'éxécuteront pendant tout le temps ou le service fontcionne
while(bRunning)
{
//Commande que le service execute
//les 4 ligne du dessous servent juste aà montrer que le service tourne et que tout les minutes il écrit test dans le fichier text
FILE * log ;
log = fopen ( "c:\\log.txt" , "a" ) ;
fprintf ( log , "test\n" ) ;
fclose ( log ) ;
Sleep(6000); //Le temps est en millisseconde, sert à temporiser l'action pour pas quelle s'execute en boucle
//on peut aussi avoir une action qui se déclanche sur un évènement partculié
Action(); //Fonction où mettre le code a executer
}
return;
}
//---------------------------------------------------------------------------
//Fonction de control de l'état du service
void WINAPI ServiceCtrlHandler(DWORD Opcode)
{
switch(Opcode)
{
//Si le service reçoit la commande de se mettre en pause
case SERVICE_CONTROL_PAUSE:
m_ServiceStatus.dwCurrentState = SERVICE_PAUSED;
break;
case SERVICE_CONTROL_CONTINUE:
m_ServiceStatus.dwCurrentState = SERVICE_RUNNING;
break;
//Si le service reçoit la commande de stopper
case SERVICE_CONTROL_STOP:
m_ServiceStatus.dwWin32ExitCode = 0;
m_ServiceStatus.dwCurrentState = SERVICE_STOPPED;
m_ServiceStatus.dwCheckPoint = 0;
m_ServiceStatus.dwWaitHint = 0;
SetServiceStatus (m_ServiceStatusHandle,&m_ServiceStatus);
bRunning=false; //donc la boucle plus haut ne s'effectura plus
break;
case SERVICE_CONTROL_INTERROGATE:
break;
}
return;
}
//---------------------------------------------------------------------------
//Si l'argument est -i enregistement du service ici
bool InstallService()
{
char strDir[1024];
SC_HANDLE schSCManager,schService;
GetCurrentDirectory(1024,strDir);
strcat(strDir,"\\connexion.exe");
schSCManager = OpenSCManager(NULL,NULL,SC_MANAGER_ALL_ACCESS);
if (schSCManager == NULL)
return false;
LPCTSTR lpszBinaryPathName=strDir;
schService = CreateService(schSCManager,"Connexion","Connexion réseaux",
SERVICE_ALL_ACCESS, // Type d'acces
SERVICE_WIN32_OWN_PROCESS, // Type de service
SERVICE_AUTO_START, // Pour le demarrage automatique
SERVICE_ERROR_NORMAL, // error control type
lpszBinaryPathName, // service's binary
NULL, // no load ordering group
NULL, // no tag identifier
NULL, // no dependencies
NULL, // Si null demarrer en tant que compte system
NULL); // Mot de passe : null si demarrer en tant que system
if (schService == NULL)
return false;
CloseServiceHandle(schService);
return true;
}
//---------------------------------------------------------------------------
//Si l'argument est -d désactivation du service ici
bool DeleteService()
{
SC_HANDLE schSCManager;
SC_HANDLE hService;
schSCManager = OpenSCManager(NULL,NULL,SC_MANAGER_ALL_ACCESS);
if (schSCManager == NULL)
return false;
hService=OpenService(schSCManager,"Connexion",SERVICE_ALL_ACCESS);
if (hService == NULL)
return false;
if(DeleteService(hService)==0)
return false;
if(CloseServiceHandle(hService)==0)
return false;
else
return true;
}
//---------------------------------------------------------------------------
//Fonction pour la connexion a internet
int Action(void)
{
WSAStartup(0x0202, &wsa);
s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
/*if(s == SOCKET_ERROR){
//printf("socket : %d\n", WSAGetLastError());
}
*/
host = gethostbyname("www.google.fr"); //l'adresse du site (necessite winsock2.h et ws2_32.lib)
memcpy(&addr, host->h_addr, host->h_length);
sin.sin_family = AF_INET;
sin.sin_port = htons(80); // HTTP
sin.sin_addr = addr;
if(SOCKET_ERROR == connect(s,(sockaddr*)&sin, sizeof(sin))){
//printf("connect : %d\n", WSAGetLastError());
}
strcpy(buf, "GET http://www.google.fr HTTP/1.0\n\n"); // la requete http
send(s, buf, strlen(buf), 0);
octet = recv(s, buf, sizeof(buf), 0);
closesocket(s);
WSACleanup();
return 0;
}
Conclusion
La source est developé sous dev C++ (si qq pouvait la tanscrir sous borland ce serait gentil) Il est très facile de modifier le nom de l'exe et du service (si necessaire faite moi signe si vous voyez pas comment) Il est tès facile aussi de rajouter des commandes a executer (pareille faite moi signe)
Je ferais peut être certaine modif pour le rendre plus simple a utilisé notament l'installation du service qui pourait etre plus simple. L'instal necessite un reboot pour demarrer le service, la désinstallation ne supprime pas l'exe... Si vous êtes interessé par ces petites modif faite moi signe si non pour mon usage perso il restera comme ca
Historique
- 22 novembre 2004 19:33:38 :
- Correction d'une erreur sur la déclaration des Handle qui generarait le msg a la compile :
Connexion.cpp: In function bool InstallService():
Connexion.cpp:176: error: invalid conversion from void* to SC_HANDLE__*
Connexion.cpp:181: error: invalid conversion from void* to SC_HANDLE__*
Connexion.cpp: In function bool DeleteService():
Connexion.cpp:200: error: invalid conversion from void* to SC_HANDLE__*
ds la fonction Installservice :
bool InstallService()
{
char strDir[1024];
SC_HANDLE schSCManager,schService;.....
}
et ds la fonction DeleteService :
bool DeleteService()
{
SC_HANDLE schSCManager;
SC_HANDLE hService;....
}
- 22 novembre 2004 19:38:18 :
- Retire le MessageBox
- 22 novembre 2004 19:54:32 :
- Rajout la creation d'un fichier test.txt qui ecrit test a chaque execution de la fonction principal a des fin de debuggage pour mieux voir ce qui ce passe
- 22 novembre 2004 20:05:04 :
- Ajout du projet DEC C++ au format zip
- 28 mars 2005 09:23:12 :
- Ajout de commentaire pour une meilleurs compréhension.
Ajout de la source pour Microsoft Visual C++
Sources du même auteur
Sources de la même categorie
Commentaires et avis
|
Derniers Blogs
IMAGINE CUP 2012, MAKE A SIGN EN FINALEIMAGINE CUP 2012, MAKE A SIGN EN FINALE par junarnoalg
Voilà qui est fait, la nouvelle est officielle ! L'équipe belge "Make a Sign" va au pays des kangourous défendre son projet dans la catégorie Software Design. http://www.imaginecup.com/CompetitionsContent/Competition/WorldwideFinalists.aspx V...
Cliquez pour lire la suite de l'article par junarnoalg KINECT 1.5 IS OUT !KINECT 1.5 IS OUT ! par Vko
La version 1.5 du Kinect For Microsoft vient tout juste de sortir ! Plein de nouveautés: Tracking de squelette en Near Mode Détection en position assise Détection faciale avec un SDK dédié Documentation et des guideline (enfin) Un out...
Cliquez pour lire la suite de l'article par Vko LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) par richardc
Mise à jour des Web API du 14 Mai
Réservez dès maintenant votre journée du 20 juin pour le Windows Azure Dev Camp 2012 à Paris
Mise à jour de Team Foundation Service
MechCommander 2 sur Windows 8
Entity Framework 5 Release Candidate e...
Cliquez pour lire la suite de l'article par richardc REACTIVE EXTENSIONS : CONSOMMER DES SERVICES AVEC RX PARTIE 3, LES PIèGES à éVITERREACTIVE EXTENSIONS : CONSOMMER DES SERVICES AVEC RX PARTIE 3, LES PIèGES à éVITER par Groc
Une mauvaise utilisation de rx lors de l'écriture d'une couche d'accès à des services peut conduire à des cas embarassants avec des erreurs mal gérées, des appels qui ne partent lorsqu'ils le devraient, et même des résultats incorrects . le tout nuis...
Cliquez pour lire la suite de l'article par Groc SHAREPOINT BLOG SITE, PROBLèME D'ARCHIVESSHAREPOINT BLOG SITE, PROBLèME D'ARCHIVES par junarnoalg
Dernièrement, nous avons migré le site
myTIC
vers un nouveau serveur SharePoint 2010. Dans les contenus que nous vouloins récupérer, nous avions un certain nombre de blogs.
Nous avons utilisé les commandes Power...
Cliquez pour lire la suite de l'article par junarnoalg
Forum
RE : SAC A DOS RE : SAC A DOS par hadjkaddour
Cliquez pour lire la suite par hadjkaddour
Logiciels
sDEVIS-FACTURES vlPRO (8.1.0.3)SDEVIS-FACTURES VLPRO (8.1.0.3)sDEVIS-FACTURES vlPRO a été mis au point pour les particuliers, créateurs, entrepreneurs, artisa... Cliquez pour télécharger sDEVIS-FACTURES vlPRO 974 Application Server (12.2.4.6)974 APPLICATION SERVER (12.2.4.6)Développez de puissantes applications dans un environnement de 'cloud computing', clusterisé, séc... Cliquez pour télécharger 974 Application Server vPicture (1.4.2.1)VPICTURE (1.4.2.1)Avec vPicture, hébergez vos images facilement et rapidement.
vPicture est un utilitaire simple, ... Cliquez pour télécharger vPicture Easy-Planning (2.2.1.6)EASY-PLANNING (2.2.1.6)Easy-Planning permet de créer des plannings sous la représentation de diagrammes et est adapté au... Cliquez pour télécharger Easy-Planning COM-BACKUP (2.0)COM-BACKUP (2.0)
COM-BACKUP est un logiciel de sauvegarde qui permet de planifier les sauvegardes de vos dossiers ...
Cliquez pour télécharger COM-BACKUP
|