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
- Confiance totale accordée à l'appelant immédiat. Ce membre ne peut pas être utilisé par du code d'un niveau de confiance partiel. Pour plus d'informations, consultez Utilisation de bibliothèques à partir de code d'un niveau de confiance partiel.