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

C# Discussion :

[débutant] application client/serveur


Sujet :

C#

  1. #1
    Membre régulier
    Inscrit en
    Janvier 2007
    Messages
    107
    Détails du profil
    Informations personnelles :
    Âge : 40

    Informations forums :
    Inscription : Janvier 2007
    Messages : 107
    Points : 73
    Points
    73
    Par défaut [débutant] application client/serveur
    Salut,


    J’ai créé une application WPF avec une base SQL server et je veux modifier cette application pour qu’elle devient une application client serveur avec une base de donné partagé (je veux que le serveur fait le traitement de tous les requêtes) mais je suis débutant en c# … je ne sais pas qu’elle méthode doit suivre.

    Merci de m’aider à connaitre quoi faire.

  2. #2
    Expert éminent sénior Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 177
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 177
    Points : 25 125
    Points
    25 125
    Par défaut
    soit tous les clients se connectent à la base (solution la plus simple)

    soit tous les clients se connectent par tcp/ip à un exe serveur, qui lui est le seul à accéder à la base de données (amène plus de possibilités ...)

    dans le 1er cas, tu pas grand chose à modifier à ton application, dans le 2ème voir wcf

  3. #3
    Membre régulier
    Inscrit en
    Janvier 2007
    Messages
    107
    Détails du profil
    Informations personnelles :
    Âge : 40

    Informations forums :
    Inscription : Janvier 2007
    Messages : 107
    Points : 73
    Points
    73
    Par défaut
    Merci Pol63 ..

    pour les deux cas qu'elle est la meilleur et qu'elle est l'avantage de chaque sollution?

    et pour la première cas t'as pas un site ou un doc pour m'aider.

  4. #4
    Expert éminent sénior Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 177
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 177
    Points : 25 125
    Points
    25 125
    Par défaut
    comme je l'ai dit, tout le monde qui se connecte sur la base c'est le plus simple, parce que tu n'as rien à changer dans ton code (si ce n'est gérer la chaine de connexion, et les éventuels bugs qui n'apparaissaient pas en mono utilisateur)

    tout le monde peut faire des select, des insert etc...
    il faut une base de données réseau (pas fichier) type sql server (ou express)
    c'est ce qui est généralement utilisé

    la 2ème solution nécessite beaucoup plus de code, car le client doit communiquer via tcp/ip avec le serveur pour lui dire ce qu'il veut (une liste de quelque chose, ajouter tel truc dans la base etc...)
    mais ca permet de faire plus de chose, comme de la notification performante et instantanée

    la notification c'est le fait que si sur un poste on ajoute/modifie/supprime une donnée (genre un client ou un produit), la modification est visible sur tous les postes qui exécute aussi l'application
    dans les 2 cas il y a plusieurs possibilités pour faire ca, soit réexécuter la requete toutes les secondes par exemple, ou alors coder un système qui permet de ne rapatrier que ce qui a été réellement modifié

    on peut aussi combiner les 2 systèmes

    bref, tout dépend de tes besoins, que tu es seul à connaitre

  5. #5
    Membre régulier
    Inscrit en
    Janvier 2007
    Messages
    107
    Détails du profil
    Informations personnelles :
    Âge : 40

    Informations forums :
    Inscription : Janvier 2007
    Messages : 107
    Points : 73
    Points
    73
    Par défaut
    Pour le moment j’utilise base de donné réseau SQL server et j’ai un problème avec les clients qui ont des baisse configuration et ils sont un peut lent lors de l’exécution de l’application et aussi j’ai u problème lors de l’insertion de date système de l’instruction dans la base car des pc ont des fausses dates qui engendre des problèmes dans l’historique … est-ce-que le WCF est la solution des ces problèmes ?

    Et si c’est oui est-ce-que je suis obligé de refaire toute l’application ou juste la modifier ??

    Merci pour les réponses.

  6. #6
    Membre régulier
    Inscrit en
    Janvier 2007
    Messages
    107
    Détails du profil
    Informations personnelles :
    Âge : 40

    Informations forums :
    Inscription : Janvier 2007
    Messages : 107
    Points : 73
    Points
    73
    Par défaut
    Et un autre problème avec l’application maintenant que si je fais un mise à jours je suis obligé de le réinstallé dans tous les pc …. C’est quoi la solution pour cette problème.

  7. #7
    Expert éminent sénior Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 177
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 177
    Points : 25 125
    Points
    25 125
    Par défaut
    la solution c'est de réfléchir avant de coder ... ca peut paraitre logique, mais c'est même une chose qu'on apprend à l'école ^^
    parce que réfléchir aux besoins multipostes après avoir développé une appli monoposte c'est pas terrible ... mais ca reste faisable, des fois c'est vendu d'une manière et revendu différemment plus tard


    wcf n'est qu'une "norme" de transfert par tcp/ip

    pour les dates qui ne sont pas identiques sur tous les pc, en général il suffit d'utiliser la date du server depuis la requete (getdate())

    après que l'appli soit lente sur les postes ca peut venir de plein de choses, de wpf, de ta gestion des données etc... et ca peut s'analyser (system.diagnotics.stopwatch pour mesurer des temps d'exécution entre 2 points, sql server profiler pour voir les perfs des requetes etc...)
    mais par exemple la différence entre un développeur lambda et un bon développeur sql peut faire qu'une requete de 2 minutes chez l'un va mettre 2 milliseconde chez l'autre ...

  8. #8
    Membre régulier
    Inscrit en
    Janvier 2007
    Messages
    107
    Détails du profil
    Informations personnelles :
    Âge : 40

    Informations forums :
    Inscription : Janvier 2007
    Messages : 107
    Points : 73
    Points
    73
    Par défaut
    Citation Envoyé par Pol63 Voir le message

    pour les dates qui ne sont pas identiques sur tous les pc, en général il suffit d'utiliser la date du server depuis la requete (getdate())
    dans les PCs clients comment utilisé getdate() pour connaitre la date de serveur ??

  9. #9
    Expert éminent sénior Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 177
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 177
    Points : 25 125
    Points
    25 125
    Par défaut
    si tu enregistres la date actuelle dans une table, getdate() est une instruction sql, et sera donc exécutée sur le serveur

    après dans windows il y a la synchronisation via serveur de temps qui peut te permettre d'avoir la même heure partout

Discussions similaires

  1. [Free Pascal] Application client/serveur en Pascal
    Par zouzou_zaza dans le forum Free Pascal
    Réponses: 15
    Dernier message: 02/09/2004, 17h57
  2. [Débutant] Application client serveur
    Par dk dans le forum Plateformes (Java EE, Jakarta EE, Spring) et Serveurs
    Réponses: 7
    Dernier message: 30/06/2004, 11h38
  3. Choix port pour application client-serveur
    Par Tiaps dans le forum Développement
    Réponses: 7
    Dernier message: 15/03/2004, 09h49
  4. Réponses: 2
    Dernier message: 01/10/2002, 12h25
  5. Langage le mieux adapté pour application client serveur ?
    Par guenus dans le forum Débats sur le développement - Le Best Of
    Réponses: 4
    Dernier message: 17/06/2002, 15h46

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