Partager via


ServerDocument, constructeur (Stream, String)

Initialise une nouvelle instance de la classe ServerDocument en utilisant un flux de données qui représente le document à charger et l'extension de nom de fichier du document.

Espace de noms :  Microsoft.VisualStudio.Tools.Applications
Assembly :  Microsoft.VisualStudio.Tools.Applications.ServerDocument (dans Microsoft.VisualStudio.Tools.Applications.ServerDocument.dll)

Syntaxe

'Déclaration
Public Sub New ( _
    stream As Stream, _
    fileType As String _
)
public ServerDocument(
    Stream stream,
    string fileType
)

Paramètres

  • stream
    Type : System.IO.Stream
    Flux de données qui représente le document à charger.
  • fileType
    Type : System.String
    Extension de nom de fichier du document, stockée dans le paramètre bytes, précédée d'un point (.) : par exemple, ".xlsx" ou ".docx."

Exceptions

Exception Condition
ArgumentNullException

Le paramètre stream est nullune référence null (Nothing en Visual Basic) ou vide.

ou

Le paramètre fileType est nullune référence null (Nothing en Visual Basic), est vide ou ne contient que des espaces blancs.

ArgumentException

La longueur du paramètre stream est égale à zéro ou la position actuelle du paramètre est à la fin du flux.

UnknownCustomizationFileException

Le paramètre fileType spécifie une extension de nom de fichier qui n'est pas prise en charge par Visual Studio Tools pour Office Runtime.

DocumentCustomizedWithPreviousRuntimeException

Le fichier spécifié par documentPath a une personnalisation qui n'a pas été créée avec Visual Studio 2010 Tools pour Office Runtime ou Visual Studio Tools pour Microsoft Office system (runtime version 3.0).

Notes

Utilisez ce constructeur pour accéder aux données en mémoire cache ou aux informations du manifeste de déploiement dans un document qui est déjà en mémoire. Lorsque vous utilisez ce constructeur, le document est ouvert en lecture/écriture.

Le paramètre fileType est utilisé uniquement pour déterminer le type de document stocké dans le tableau d'octets. La valeur de fileType est associée à l'un des types de fichiers pris en charge pour les personnalisations au niveau du document. Aucune tentative d'ouverture du fichier n'est effectuée. Vous pouvez passer éventuellement un nom de fichier complet (par exemple, "Workbook1.xlsx"), mais dans ce cas, seule l'extension de nom de fichier est utilisée. Pour plus d'informations sur les types de fichiers pris en charge, consultez Architecture des personnalisations au niveau du document.

Pour accéder au tableau d'octets du document après avoir appelé ce constructeur, utilisez la propriété Document.

Exemples

Le code suivant utilise le constructeur ServerDocument(Stream, String) pour créer un ServerDocument depuis un FileStream qui contient un classeur Excel portant l'extension .xlsx. Le code affiche ensuite l'URL du manifeste de déploiement de la personnalisation jointe au document.

Cet exemple nécessite :

  • Projet d'application console ou un autre projet non-Office.

  • Références aux assemblys suivants :

    • Microsoft.VisualStudio.Tools.Applications.ServerDocument.dll et Microsoft.VisualStudio.Tools.Applications.Runtime.dll (si le projet cible .NET Framework 4 ou .NET Framework 4.5).

      ou

    • Microsoft.VisualStudio.Tools.Applications.ServerDocument.v10.0.dll et Microsoft.VisualStudio.Tools.Applications.Runtime.v9.0.dll (si le projet cible le .NET Framework 3.5).

  • Instructions Imports (pour Visual Basic) ou using pour C#) pour les espaces de noms Microsoft.VisualStudio.Tools.Applications et Microsoft.VisualStudio.Tools.Applications.Runtime au haut de votre fichier de code.

Private Sub CreateServerDocumentFromStream(ByVal documentPath As String)
    Dim runtimeVersion As Integer = 0
    Dim serverDocument1 As ServerDocument = Nothing
    Dim stream As System.IO.FileStream = Nothing

    Try
        runtimeVersion = ServerDocument.GetCustomizationVersion(documentPath)
        If runtimeVersion = 3 Then
            stream = New System.IO.FileStream(documentPath, System.IO.FileMode.Open)
            serverDocument1 = New ServerDocument(stream, "*.xlsx")
            MessageBox.Show("The URL of the deployment manifest is: " & vbLf & _
                serverDocument1.DeploymentManifestUrl.ToString())
        End If

    Catch ex As System.IO.FileNotFoundException
        System.Windows.Forms.MessageBox.Show("The specified document does not exist.")
    Catch ex As UnknownCustomizationFileException
        System.Windows.Forms.MessageBox.Show("The specified document has a file " & _
            "extension that is not supported by Visual Studio Tools for Office.")
    Finally
        If Not (serverDocument1 Is Nothing) Then
            serverDocument1.Close()
        End If
        If Not (stream Is Nothing) Then
            stream.Close()
        End If
    End Try
End Sub
private void CreateServerDocumentFromStream(string documentPath)
{
    int runtimeVersion = 0;
    ServerDocument serverDocument1 = null;
    System.IO.FileStream stream = null;

    try
    {
        runtimeVersion = ServerDocument.GetCustomizationVersion(documentPath);
        if (runtimeVersion == 3)
        {
            stream = new System.IO.FileStream(
                documentPath, System.IO.FileMode.Open);
            serverDocument1 = new ServerDocument(stream,
                "*.xlsx");
            MessageBox.Show("The URL of the deployment manifest is: \n" +
                serverDocument1.DeploymentManifestUrl.ToString());
        }
    }
    catch (System.IO.FileNotFoundException)
    {
        System.Windows.Forms.MessageBox.Show("The specified document does not exist.");
    }
    catch (UnknownCustomizationFileException)
    {
        System.Windows.Forms.MessageBox.Show("The specified document has a file " +
            "extension that is not supported by Visual Studio Tools for Office.");
    }
    finally
    {
        if (serverDocument1 != null)
            serverDocument1.Close();
        if (stream != null)
            stream.Close();
    }
}

Sécurité .NET Framework

Voir aussi

Référence

ServerDocument Classe

ServerDocument, surcharge

Microsoft.VisualStudio.Tools.Applications, espace de noms