Document.ProtectDocument Метод (2007 System)
Обновлен: Июль 2008
Вызывается средой выполнения Visual Studio Tools for Office, поэтому к документу еще раз применяется защита паролем, уже после того, как кэшированные данные были сохранены.
Пространство имен: Microsoft.Office.Tools.Word
Сборка: Microsoft.Office.Tools.Word.v9.0 (в Microsoft.Office.Tools.Word.v9.0.dll)
Синтаксис
'Декларация
Protected Overridable Sub ProtectDocument
'Применение
Me.ProtectDocument()
protected virtual void ProtectDocument()
Заметки
Перегрузите этот метод в проекте уровня документа для Word, если документ защищен пароле и содержит кэшированные данные, которые могут быть изменены во время выполнения. При реализации этого метода используйте для защиты документа метод Protect.
По умолчанию изменения кэшированных данных в документе, защищенном паролем, не сохраняются при сохранении документа. Чтобы сохранить изменения в кэшированных данных, необходимо перегрузить в проекте следующие методы:
UnprotectDocument. При сохранении документа этот метод вызывается средой выполнения Visual Studio Tools for Office. Добавьте код в этот метод, чтобы на время снять защиту с документа. Это позволяет сохранить изменения кэшированных данных.
ProtectDocument. Этот метод вызывается средой выполнения Visual Studio Tools for Office после сохранения документа. Добавьте код в данный метод, чтобы снова применить защиту к документу.
Дополнительные сведения см. в разделе Практическое руководство. Кэширование данных в документе, защищенном паролем.
Среда выполнения Visual Studio Tools for Office вызывает метод ProtectDocument, даже если кэшированные данные не могут быть сохранены из-за некоторых ошибок, не связанных с защитой паролем. Например, если вы применяете интерфейс ICachedType для настройки хранения кэшированных данных в вашем документе, метод ProtectDocument вызывается, даже если ваша реализация ICachedType вызывает исключение, которое запрещает сохранение кэшированных данных.
Примеры
В следующем примере кода демонстрируется перегрузка метода ProtectDocument для восстановления защиты, убранной при перегрузке метода UnprotectDocument. Чтобы использовать данный код, запустите его из класса ThisDocument в проекте уровня документа для приложения Word. В этом коде предполагается, что пароль хранится в поле с именем securelyStoredPassword.
<CachedAttribute()> _
Public CachedString As String = "This string is cached in the document."
Private protectionTypeValue As Word.WdProtectionType
Protected Overrides Sub UnprotectDocument()
If Me.ProtectionType <> Word.WdProtectionType.wdNoProtection Then
protectionTypeValue = Me.ProtectionType
Me.Unprotect(securelyStoredPassword)
End If
End Sub
Protected Overrides Sub ProtectDocument()
Me.Protect(protectionTypeValue, Password:=securelyStoredPassword)
End Sub
[CachedAttribute]
public string CachedString = "This string is cached in the document.";
private Word.WdProtectionType protectionTypeValue;
protected override void UnprotectDocument()
{
if (this.ProtectionType != Word.WdProtectionType.wdNoProtection)
{
protectionTypeValue = this.ProtectionType;
this.Unprotect(ref securelyStoredPassword);
}
}
protected override void ProtectDocument()
{
this.Protect(protectionTypeValue, ref missing,
ref securelyStoredPassword, ref missing, ref missing);
}
Разрешения
- Полное доверие для непосредственно вызывающего метода. Этот член не может быть использован частично доверенным кодом. Дополнительные сведения см. в разделе Использование библиотек из не вполне надежного кода.
См. также
Ссылки
Microsoft.Office.Tools.Word - пространство имен
Другие ресурсы
Практическое руководство. Кэширование данных в документе, защищенном паролем
Журнал изменений
Дата |
Журнал изменений |
Причина |
---|---|---|
Июль 2008 |
Новый раздел. |
Изменение функции SP1. |