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

ASP.NET Discussion :

problème de chemin implicite dans DOT.NEt


Sujet :

ASP.NET

  1. #1
    Membre habitué
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Janvier 2005
    Messages
    534
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 534
    Points : 188
    Points
    188
    Par défaut problème de chemin implicite dans DOT.NEt
    bonjour

    dans ma chaine de connection OleDB j'ai :
    strCnx = "Provider=Microsoft.Jet.OLEDB.4.0;"+
    "Data Source = localhost\\data\test042007.mdb";
    Cnx1 = new OleDbConnection(strCnx);
    Cnx1.Open();

    systématiquement, lors de l'exécution de ce code simple, j'ai un message d'erreur comme quoi la BD n'est pas trouvée.
    Ceci est normal vu qu'on me rajoute systématiquement une chaîne de caractère devant la mienne et qu'on obtient :

    En Allemand ...

    Serverfehler in der Anwendung '/Test02052007'.

    'C:\WINDOWS\system32\localhost\data est042007.mdb' ist kein zulässiger Pfad. Stellen Sie sicher, dass der Pfad richtig eingegeben wurde und dass Sie mit dem Server, auf dem sich die Datei befindet, verbunden sind.

    l'erreur est en gras ! pourquoi me met-il "C:\WINDOWS\system32" ?
    Où puis-je reconfigurer cela ? Dans quel onglet ?

  2. #2
    Membre habitué
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Janvier 2005
    Messages
    534
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 534
    Points : 188
    Points
    188
    Par défaut
    le message d'erreur que j'ai dans IE :


    [OleDbException (0x80004005): Kein zulässiger Dateiname.]
    System.Data.OleDb.OleDbConnection.ProcessResults(Int32 hr)
    System.Data.OleDb.OleDbConnection.InitializeProvider()
    System.Data.OleDb.OleDbConnection.Open()
    test02052007.WebForm1.Page_Load(Object sender, EventArgs e) in c:\inetpub\wwwroot\test02052007\webform1.aspx.cs:31
    System.Web.UI.Control.OnLoad(EventArgs e)
    System.Web.UI.Control.LoadRecursive()
    System.Web.UI.Page.ProcessRequestMain()

    on voit bien là en gras que le chemin est bon pourtant

    Quel "objet" ou interface ou module pourrait modifier le path ?

  3. #3
    Rédacteur
    Avatar de Giovanny Temgoua
    Profil pro
    Étudiant
    Inscrit en
    Novembre 2003
    Messages
    3 830
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2003
    Messages : 3 830
    Points : 4 006
    Points
    4 006
    Par défaut
    Bonsoir,

    Il faut peut être mieux nous traduire ton message en Allemand parce que ...
    Et aussi tu peux utiliser les balises [ QUOTE ] pour mettre ton message en forme (j'ai fait un exemple sur ton second message )

    Tu utilises quel environnement ? Parce que dans VS, si tu ajoutes une base de données dans le Server Explorer, il teste si la connexion peut être établie par rapport à la chaîne donnée...

    Ton erreur est vraiment bizzare cela dit Tu nous a posté tout le code ?
    Tu as essayé en utilisant un chemin relatif ? genre :

    ?

  4. #4
    Membre habitué
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Janvier 2005
    Messages
    534
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 534
    Points : 188
    Points
    188
    Par défaut
    bonjour et merci de ta réponse
    désolé pour la mise en forme de mon texte, elle me paraissait claire (à tort) et je n'ai pensé à la balise [Quote]

    Le problème est que windows ( ou dot net) me rajoute systématiquement le chemin "c:\windows\system32" devant celui que je mets dans le code C#.

    Donc, en mettant le chemin relatif "data\monfichier.mdb", faisant référence à "c:\inetpub\wwwroot\test02052007\data\mofichier.mdb",
    j'obtiens systématiquement
    "c:\windows\system32\c:\inetpub\wwwroot\test02052007\data\mofichier.mdb"
    et un message d'erreur

    Ceci uniquemqnet quand je lance l'éxecution
    L'erreur s'affiche dans Internet Explorer

    j'espère ete plus clair à présent

    merci

  5. #5
    Membre à l'essai

    Inscrit en
    Mai 2007
    Messages
    6
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 6
    Points : 18
    Points
    18
    Par défaut Escape Sequence
    Citation Envoyé par Hepil
    bonjour

    dans ma chaine de connection OleDB j'ai :
    strCnx = "Provider=Microsoft.Jet.OLEDB.4.0;"+
    "Data Source = localhost\\data\test042007.mdb";
    Cnx1 = new OleDbConnection(strCnx);
    Cnx1.Open();

    systématiquement, lors de l'exécution de ce code simple, j'ai un message d'erreur comme quoi la BD n'est pas trouvée.
    Ceci est normal vu qu'on me rajoute systématiquement une chaîne de caractère devant la mienne et qu'on obtient :

    En Allemand ...

    Serverfehler in der Anwendung '/Test02052007'.

    'C:\WINDOWS\system32\localhost\data est042007.mdb' ist kein zulässiger Pfad. Stellen Sie sicher, dass der Pfad richtig eingegeben wurde und dass Sie mit dem Server, auf dem sich die Datei befindet, verbunden sind.

    l'erreur est en gras ! pourquoi me met-il "C:\WINDOWS\system32" ?
    Où puis-je reconfigurer cela ? Dans quel onglet ?


    Bonjour en voyant ton code je me suis aperçu que tu avais mis
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    strCnx = "Provider=Microsoft.Jet.OLEDB.4.0;"+
    "Data Source = localhost\\data\test042007.mdb";
    Cnx1 = new OleDbConnection(strCnx);
    Cnx1.Open();
    il y'a une erreur, tu devrais remplacer par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    strCnx = @"Provider=Microsoft.Jet.OLEDB.4.0;"+
    "Data Source = localhost\data\test042007.mdb";
    Cnx1 = new OleDbConnection(strCnx);
    Cnx1.Open();
    le @ permet d'ignorer les sequénce d'echapement dans le .Net.
    car "...\test" le \t est consideré comme une tabulation.

    une question? ta base de données se trouvvent elle dans un repertoire qui s'appele localhost ou c'est juste pour reference a la machine locale.

    [Pensez aux balises QUOTE et CODE - Giovanny]

  6. #6
    Membre habitué
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Janvier 2005
    Messages
    534
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 534
    Points : 188
    Points
    188
    Par défaut
    effectivement, il y a plusieurs erreur, tu as entièrement raison
    j'ai placé les '@' devant les chaîne de caractères et ça marche, mais pas en chemin relatif
    Dernier code fonctionnel :

    strCnx = @"Provider=Microsoft.Jet.OLEDB.4.0;"+
    //@"Data Source = c:\inetpub\wwwroot\test02052007\data\test042007.mdb";
    @"Data Source = data\test042007.mdb";
    Cnx1 = new OleDbConnection(strCnx);
    Cnx1.Open();
    la ligne en commentaire (//...( fonctionne parfaitement
    celle qui est active actuellement, par rapport à un chemin relatif, génère un message d'erreur :

    "c:\windows\system32\data\test02052007\test042007.mdb" non trouvé

    normal !!! ce n'est pas le bon chemin ! d'où vient-il ce chemin ?

    la bonne ligne est celle du haut

  7. #7
    Membre à l'essai

    Inscrit en
    Mai 2007
    Messages
    6
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 6
    Points : 18
    Points
    18
    Par défaut
    Citation Envoyé par Hepil
    effectivement, il y a plusieurs erreur, tu as entièrement raison
    j'ai placé les '@' devant les chaîne de caractères et ça marche, mais pas en chemin relatif
    Dernier code fonctionnel :



    la ligne en commentaire (//...( fonctionne parfaitement
    celle qui est active actuellement, par rapport à un chemin relatif, génère un message d'erreur :

    "c:\windows\system32\data\test02052007\test042007.mdb" non trouvé

    normal !!! ce n'est pas le bon chemin ! d'où vient-il ce chemin ?

    la bonne ligne est celle du haut
    L'utilité de Server.MapPath, réside dans le fait qu'elle recupere le chemin absolue d'un fichier hébérgé sur ton site, donc au lieu d'ecrire
    datasource=@"datasource=c:\inteput\wwwroot\..."
    Server.MapPath('fichier.mdb'), recupere le chemin absolue vers ce fichier, et pour ce qui est de l'utilisation du chemin relatif, sache que ça a marché pour moi, mais je n'ai essayé que des applications windows et pas web.

  8. #8
    Membre habitué
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Janvier 2005
    Messages
    534
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 534
    Points : 188
    Points
    188
    Par défaut
    ça avance :

    voici le dernier code mais toujours une erreur pour le chemin relatif

    string MyPass = Server.MapPath("data\test042007.mdb");
    strCnx = @"Provider=Microsoft.Jet.OLEDB.4.0;"+
    //@"Data Source = c:\inetpub\wwwroot\test02052007\data\test042007.mdb";
    //@"Data Source = data\test042007.mdb";
    @"Data Source = " + MyPass;
    Cnx1 = new OleDbConnection(strCnx);
    Cnx1.Open();
    et le message d'erreur :
    http://album.club-internet.fr/album/...id_img=1891540

    Essayons de le traduire :

    Erreur du serveur dans l'application 'Test02052007'


    Nom de fichier nom non valide
    Description :

    En executant la requête web actuelle apparait une erreur mal assimilée.
    Contrôlez la pile d'execution pour afficher des informations complémentaires sur cette erreur et les mettre en évidence.

    Détails de l'exception: System.Data.OleDb.OleDbException : pas de nom de fichier valide


    Code erroné:

    fichier source :
    c:\inetpub\wwwroot\test02052007\webform1.aspx.cs ligne: 34
    d'après tous les test effectués et le code proposé dans le message d'erreur, c'est à l'ouverture de la connexion que l'on a cette exception

  9. #9
    Membre à l'essai

    Inscrit en
    Mai 2007
    Messages
    6
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 6
    Points : 18
    Points
    18
    Par défaut
    Citation Envoyé par Hepil
    ça avance :

    voici le dernier code mais toujours une erreur pour le chemin relatif



    et le message d'erreur :
    http://album.club-internet.fr/album/...id_img=1891540
    essaies sans utiliser Server.MapPath, en donnant le chemin absolu, d'aprés la traduction que j'ai cette erreur est due à un nom de fichier incorrect.

    PS: tu peux m'envoyer le tracet de la pile d'execution.

  10. #10
    Membre habitué
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Janvier 2005
    Messages
    534
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 534
    Points : 188
    Points
    188
    Par défaut
    si je mets le chemin complet (absolu), tout fonctionne, mais il mettre un chemin relatif sinon il faudra que je modifie le code dès que je copie le site sur un serveur ... et puis il y a un problème à résoudre !
    A mon sens je ne dois pas laisser cela non résolu

  11. #11
    Membre habitué
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Janvier 2005
    Messages
    534
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 534
    Points : 188
    Points
    188
    Par défaut
    suite des informations :

    Stapelüberwachung: pile d'éxécution :


    [OleDbException (0x80004005): Kein zulässiger Dateiname.] Pas de nom de fichier valable
    System.Data.OleDb.OleDbConnection.ProcessResults(Int32 hr)
    System.Data.OleDb.OleDbConnection.InitializeProvider()
    System.Data.OleDb.OleDbConnection.Open()
    test02052007.WebForm1.Page_Load(Object sender, EventArgs e) in c:\inetpub\wwwroot\test02052007\webform1.aspx.cs:34
    System.Web.UI.Control.OnLoad(EventArgs e)
    System.Web.UI.Control.LoadRecursive()
    System.Web.UI.Page.ProcessRequestMain()


    --------------------------------------------------------------------------------
    Versionsinformationen: Microsoft .NET Framework Version:1.1.4322.2032; ASP.NET-Version:1.1.4322.2032

Discussions similaires

  1. Problème de chemin absolu dans une tâche
    Par ToniConti dans le forum Pentaho
    Réponses: 4
    Dernier message: 13/04/2010, 17h07
  2. Réponses: 5
    Dernier message: 27/07/2007, 12h42
  3. [VB.NET][2.0] Problème de Drag&Drop dans un ListView
    Par Angath dans le forum Windows Forms
    Réponses: 1
    Dernier message: 29/11/2006, 15h47
  4. Problème paramètre chemin dans url
    Par m@t dans le forum Langage
    Réponses: 17
    Dernier message: 09/03/2006, 22h09
  5. [VB.NET] Problème avec un OptionButton dans Excel 2003
    Par alfprod dans le forum Windows Forms
    Réponses: 3
    Dernier message: 09/09/2004, 13h40

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