Sie sind zurzeit offline. Es wird auf die erneute Herstellung einer Internetverbindung gewartet.

Update: Kann nicht Code-Behind-Dateien kompilieren, die src-Attribut auf einer UNC-Freigabe verwenden

Wichtig: Dieser Artikel wurde maschinell und nicht von einem Menschen übersetzt. Die Microsoft Knowledge Base ist sehr umfangreich und ihre Inhalte werden ständig ergänzt beziehungsweise überarbeitet. Um Ihnen dennoch alle Inhalte auf Deutsch anbieten zu können, werden viele Artikel nicht von Menschen, sondern von Übersetzungsprogrammen übersetzt, die kontinuierlich optimiert werden. Doch noch sind maschinell übersetzte Texte in der Regel nicht perfekt, insbesondere hinsichtlich Grammatik und des Einsatzes von Fremdwörtern sowie Fachbegriffen. Microsoft übernimmt keine Gewähr für die sprachliche Qualität oder die technische Richtigkeit der Übersetzungen und ist nicht für Probleme haftbar, die direkt oder indirekt durch Übersetzungsfehler oder die Verwendung der übersetzten Inhalte durch Kunden entstehen könnten.

Den englischen Originalartikel können Sie über folgenden Link abrufen: 313105
Dieser Artikel wurde archiviert. Er wird im vorliegenden Zustand bereitgestellt und nicht mehr aktualisiert.
Problembeschreibung
Wenn beim Kompilieren ein Webformular, der Kompilierung in ASP.NET fehlschlagen und möglicherweise die folgende Fehlermeldung sinngemäß (oder ähnlich):
Compiler-Fehlermeldung: CS2001: Quelldatei
'\\server\sharename\webform1.aspx.cs' konnte nicht gefunden werden.
Dieser Fehler kann auftreten, wenn folgenden Bedingungen erfüllt sind:
  • Das Code-Behind-Modell wird verwendet.
  • Die Seite verwendet die dynamische Kompilierung mit dem Src -Attribut und der Quelle Attribut verweist auf eine Datei auf einem Remotecomputer mithilfe eines UNC (Universal Naming Convention) gemeinsam nutzen.
  • Identitätswechsel ist in der Datei Web.config aktiviert.
Ursache
Dieses Problem tritt auf, weil der Compiler mit der Identität des ein Arbeitsprozess gestartet wird und der Arbeitsprozess möglicherweise nicht zum Lesen der Remotefreigabe. Da ASP.NET das Identitätswechseltoken, verwendet um die Seite gelesen, liest ASP.NET die Seite erfolgreich.
Lösung
Verwenden Sie eine der folgenden Methoden, um dieses Problem zu beheben:
  • Gewähren Sie der Freigabe Zugriff auf das Konto, das für den Workerprozess verwendet. Wenn Sie ein Systemkonto oder ein Netzwerkdienst verwenden, können Sie auf das Computerkonto Zugriff gewähren.

    Gehen Sie folgendermaßen vor um Zugriff auf das Computerkonto ermöglichen:
    1. Klicken Sie mit der rechten Maustaste auf die Freigabe, und klicken Sie dann auf Eigenschaften .
    2. Klicken Sie auf der Registerkarte Freigabe auf Berechtigungen , und klicken Sie dann auf Hinzufügen .
    3. Geben Sie den Namen des Webservers, und klicken Sie auf Namen überprüfen . Dies zeigt als $ Computername unter Freigabeberechtigungen im Dialogfeld Berechtigungen für diese Freigabe.
  • Verwenden Sie Code-Behind-Dateien mit vorkompilierten Dynamic Link Libraries (DLLs) anstelle von dynamischen Kompilierung.
  • Verwenden Sie einzelne Seitendateien anstelle von Code-Behind-Dateien.
  • Führen Sie den Workerprozess als ein Konto, das die Freigabe zugreifen kann. Um dies zu konfigurieren, verwenden Sie Benutzer Namen und das Kennwort Attribute des Elements ProcessModel der Datei Machine.config.
Status
Microsoft hat bestätigt, dass es sich hierbei um ein Problem bei den in diesem Artikel Microsoft-Produkten handelt. Dieser Fehler wurde behoben in ASP.NET (im Lieferumfang von .NET Framework enthalten) 1.1 und .NET Framework 1.1.
Weitere Informationen

Schritte zum Reproduzieren des Verhaltens

  1. Erstellen Sie eine ASPX-Seite mit dem Namen WebForm1.aspx.
  2. Der Page-Direktive verwenden eine der folgenden Beispiele:
    <%@ Page language="c#"  Codebehind="WebForm1.aspx.cs"  Src = "WebForm1.aspx.cs" %>					
    -oder-
    <%@ Page language="vb"  Codebehind="WebForm1.aspx.vb"  Src = "WebForm1.aspx.vb" %>					
  3. Erstellen Sie eine Code-Behind-Seite, und nennen Sie es nach der Seitendirektive, die Sie in Schritt 2 ausgewählt haben.
  4. Fügen Sie einen Domänenbenutzer (Domäne\Benutzer) als Administrator auf dem Computer.
  5. Erstellen Sie eine Freigabe und erteilen Sie vollständige Berechtigungen für den Domänenbenutzer.
  6. Im Internetdienste-Manager Erstellen einer Anwendung Microsoft Internet Information Server (IIS), und verwenden Sie die Domäne, für Connect - als.
  7. Erstellen Sie ein virtuelles Verzeichnis, in der Anwendung, die auf die Freigabe zeigt, die Sie zuvor erstellt haben.
  8. Verschieben Sie die WebForm1.aspx und die Code-Behind-Datei für die Freigabe.
  9. Erstellen Sie eine neue Web.config-Datei, und fügen Sie folgenden Code:
    <?xml version="1.0" encoding="utf-8" ?><configuration>  <system.web>    <authentication mode="Windows" />    <identity impersonate="true" userName="domain\user" password="password" />  </system.web></configuration>					
  10. Kopieren Sie die Web.config-Datei in das virtuelle Verzeichnis für die Webanwendung, um die Datei auf dem IIS-Anwendung hinzuzufügen.
  11. Wechseln Sie zu der Seite.
Kbreadme codebehind

Warnung: Dieser Artikel wurde automatisch übersetzt.

Eigenschaften

Artikelnummer: 313105 – Letzte Überarbeitung: 02/24/2014 15:39:04 – Revision: 2.3

Microsoft ASP.NET 1.0, Microsoft .NET Framework 1.0

  • kbnosurvey kbarchive kbmt kbfix kbbug kbconfig kbdeployment kbnofix kbreadme kbsecurity kbweb KB313105 KbMtde
Feedback