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
- 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.