ServerDocument 构造函数 (array<Byte[], String) (2007 system)
更新:2007 年 11 月
使用表示要加载的文档的字节数组和该文档的文件扩展名,初始化 ServerDocument 类的新实例。
命名空间: Microsoft.VisualStudio.Tools.Applications
程序集: Microsoft.VisualStudio.Tools.Applications.ServerDocument.v9.0(在 Microsoft.VisualStudio.Tools.Applications.ServerDocument.v9.0.dll 中)
语法
声明
Public Sub New ( _
bytes As Byte(), _
fileType As String _
)
用法
Dim bytes As Byte()
Dim fileType As String
Dim instance As New ServerDocument(bytes, fileType)
public ServerDocument(
byte[] bytes,
string fileType
)
参数
bytes
类型:array<System.Byte[]一个表示要加载的文档的字节数组。
fileType
类型:System.String文档的文件扩展名,存储在 bytes 参数中,前面有一个句点 (.),例如“.xlsx”或“.docx”。
异常
异常 | 条件 |
---|---|
ArgumentNullException | bytes 参数为 nullnull 引用(在 Visual Basic 中为 Nothing) 或为空。 - 或 - fileType 参数为 nullnull 引用(在 Visual Basic 中为 Nothing) 或为空,或者完全由空白字符组成。 |
UnknownCustomizationFileException | Visual Studio Tools for Office 不支持 fileType 参数指定的文件扩展名。 |
DocumentCustomizedWithPreviousRuntimeException | documentPath 指定的文件具有使用早期版本的 Visual Studio Tools for Office 运行时创建的自定义项。 |
备注
使用此构造函数可以访问已经在内存中的文档的缓存数据或部署清单信息。使用此构造函数时,文档以读/写访问权限打开。
fileType 参数仅用于确定存储在字节数组中的文档的类型。fileType 的值映射到文档级自定义项所支持的文件类型之一。不尝试打开文件。您可以选择传入完整的文件名(例如“Workbook1.xlsx”),但即使这样做,也只使用文件扩展名。有关支持的文件类型的更多信息,请参见文档级自定义项的体系结构。
若要在调用此构造函数后访问文档的字节数组,请使用 Document 属性。
示例
下面的代码示例使用 ServerDocument(array<Byte[], String) 构造函数,根据文件扩展名为 .xlsx 的 Excel 工作簿的字节数组创建新的 ServerDocument。然后该示例使用 Document 属性显示文档的字节数。
此示例需要在代码文件顶部使用对 Microsoft.VisualStudio.Tools.Applications.ServerDocument.v9.0.dll 和 Microsoft.VisualStudio.Tools.Applications.Runtime.v9.0.dll 程序集的引用,并对 Microsoft.VisualStudio.Tools.Applications 和 Microsoft.VisualStudio.Tools.Applications.Runtime 命名空间使用 Imports(对于 Visual Basic)或 using(对于 C#)语句。
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();
}
}
权限
- 对直接调用方的完全信任。此成员不能由部分信任的代码使用。有关更多信息,请参见通过部分受信任的代码使用库。