Partager via


ServerDocument, constructeur (array<Byte , String)

Initialise une nouvelle instance de la classe ServerDocument en utilisant un tableau d'octets 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 ( _
    bytes As Byte(), _
    fileType As String _
)
public ServerDocument(
    byte[] bytes,
    string fileType
)

Paramètres

  • bytes
    Type : array<System.Byte[]
    Tableau d'octets 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 bytes 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.

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 (version 3,0 runtime).

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

L'exemple de code suivant utilise le constructeur ServerDocument(array<Byte[], String) pour créer un ServerDocument à partir d'un tableau d'octets qui contient un classeur Excel avec l'extension de nom de fichier .xlsx.L'exemple utilise ensuite la propriété Document pour afficher le nombre d'octets contenus dans le 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 CreateServerDocumentFromByteArray(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
            ' Read the file into a byte array.
            stream = New System.IO.FileStream(documentPath, System.IO.FileMode.Open, _
                System.IO.FileAccess.Read)
            Dim buffer(Fix(stream.Length)) As Byte
            stream.Read(buffer, 0, Fix(buffer.Length))

            ' Display the number of bytes in the document.
            serverDocument1 = New ServerDocument(buffer, "*.xlsx")
            MessageBox.Show("The Document property contains " & _
                serverDocument1.Document.Length.ToString() & " bytes.")
        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 CreateServerDocumentFromByteArray(string documentPath)
{
    int runtimeVersion = 0;
    ServerDocument serverDocument1 = null;
    System.IO.FileStream stream = null;

    try
    {
        runtimeVersion = ServerDocument.GetCustomizationVersion(documentPath);
        if (runtimeVersion == 3)
        {
            // Read the file into a byte array.
            stream = new System.IO.FileStream(
                documentPath, System.IO.FileMode.Open,
                System.IO.FileAccess.Read);
            byte[] buffer = new byte[(int)stream.Length];
            stream.Read(buffer, 0, (int)buffer.Length);

            // Display the number of bytes in the document.
            serverDocument1 = new ServerDocument(buffer,
                "*.xlsx");
            MessageBox.Show("The Document property contains " +
                serverDocument1.Document.Length.ToString() +
                " bytes.");
        }
    }
    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