Запрет на распечатку документов с чужого компьютераИсточник: wordexpert Фнтон Конкин
Как можно поставить в Word запрет на распечатку через чужой принтер? Я думаю, надо запретить не распечатку через чужой принтер, а распечатку с чужого компьютера. Я предлагаю простой, хоть и не очень надёжный способ определить "свой" компьютер - по имени пользователя, заданному в Word. Приведённый ниже VB код, хоть и можно обнаружить в редакторе Visual Basic, но в списке макросов он не виден, так как все процедуры объявлены как Private. Делаем следующее. Защищаемый документ должен быть открыт в Word. Открываем редактор Visual Basic («Alt»+«F11»). В окне проектов щёлкаем правой кнопкой мышки по проекту, относящемуся к данному документу (в прилагаемом файле примера это проект CancelPrinting). Выбираем меню Insert -> Class Module. В окне свойств меняем имя класса, например на PrintController. В окне кода классового модуля PrintController набираем следующий код: Option Explicit Private WithEvents app As Word.Application Public Property Set ApplicationObject(value As Word.Application) 'установить ссылку на объект приложения Set app = value End Property Private Sub app_DocumentBeforePrint(ByVal Doc As Document, Cancel As Boolean) 'проверить имя пользователя If app.UserName <> "Антон Кокин" Then 'отменить печать Cancel = True Call MsgBox("Распечатка запрещена. Извините!", _ vbExclamation + vbOKOnly, "Test") End If End Sub Заменяем текст "Антон Кокин" на своё имя, как оно задано в настройках Word. Теперь в окне проектов дважды щёлкаем левой кнопкой мышки по модулю ThisDocument, находящемуся под проектом данного документа (в прилагаемом файле примера это CancelPrinting). Открывается окно кода этого модуля. Там набираем следующий код: Option Explicit Private controller As PrintController Private Sub Document_New() 'эта процедура работает при создании нового документа, 'используя данный как шаблон SetPrintController MsgBox "Новый документ" End Sub Private Sub Document_Open() 'эта процедура работает при каждом открытии документа SetPrintController MsgBox "Открыть" End Sub Private Sub SetPrintController() 'установить ссылку на новый экземпляр класса Set controller = New PrintController 'передать экземпляру класса ссылку на объект приложения Set controller.ApplicationObject = Word.Application End Sub Сохраняем документ. Чтобы код начал работать, надо закрыть и опять открыть документ. Если же нужна большая безопасность, предлагаю заменить проверку имени на проверку предварительно созданного уникального ключа в регистре с помощью System.ProfileString. Надо будет также как-то защитить VB модули с помощью пароля. |