oldi

Системы и механизмы защиты программных продуктов

Рубен Садоян, rouben@mmtech.ru

Введение

Простая проверка поврежденного носителя

Ограничение числа установок программы

Ограничение числа запусков программы (limited use copy)

Контрольные вопросы

Временные (умирающие) версии

Версии, работающие с ограничениями

Анализ поверхности поврежденного носителя

Аппаратные ключи (dongles)

Сетевая защита

Немного о принятии решения

А как же быть с данными?

Crypto ++ SDK 3.0

Gus

CripKey

Microcosm Copy Protection

Dinkey Dongles

PC Guard

SafeSerial OCX для Windows 95, 98, NT, 2000

Wibu — Key

Lock & Key

Windows Protection Tool-Kit™

Sheriff

Hardlock Bistro

Введение

Разработка программного обеспечения — вещь серьезная. Тем не менее производство программного обеспечения куда серьезней, а его защита от несанкционированного использования актуальна настолько, насколько актуален сам программный продукт. Ясное дело, что никто не будет «ломать», а тем более тиражировать никому не нужное программное обеспечение. Разве только какой-нибудь азартный хакер, да и тот ради спортивного интереса «сломает» тривиальную программу, защищенную далеко не тривиальным образом.

Несмотря на наличие всего комплекса законодательных и правовых мер по защите авторских и смежных прав на интеллектуальную собственность, ситуация с так называемым «черным» или, как его чаще называют, пиратским рынком программного обеспечения остается весьма плачевной. К примеру, ни для кого не секрет, что подавляющее большинство программного обеспечения в России нелицензионное, да что тут говорить, достаточно вспомнить пресловутую «Горбушку», где за умеренную плату (около 60 руб.) можно приобрести компакт-диск, в то время как цена содержащегося в нем лицензионного программного обеспечения превышает сумму примерно в 1000 раз. Разумеется, подобная проблема существует не только на отечественном рынке программного обеспечения, но и во всем мире. Однако следует отметить, что так остро, как в России, она почти нигде не стоит. В частности, если средний процент пиратского программного обеспечения по Европе составляет 20-40%, то в России эта цифра близка к 95%.

На фоне этого может показаться, что защищать программное обеспечение не имеет смысла — все равно сломают, однако это далеко не так.

Тут вполне уместно разобраться, что и от кого следует защищать. Данная статья посвящена как раз изложению основных принципов и механизмов защиты программного обеспечения.

Ниже будут рассмотрены основные программистские уловки для разработки самостоятельных механизмов защиты и приведен обзор нескольких существующих решений для автоматизации этого процесса. Статья рассчитана как на разработчиков программного обеспечения, так и на рядовых пользователей персональных компьютеров.

Так что же и от кого следует защищать?

В общих чертах ответ на этот вопрос выглядит следующим образом:

  1. Выполняемые модули программы — от работы в несанкционированных условиях;
  2. Данные — от их использования независимо от выполняемых модулей;
  3. Программу — от ее несанкционированного копирования и/или применения;

Разумеется, в зависимости от характера защищаемого программного обеспечения этот список может меняться.

Кроме того, характер применяемых решений для защиты программ напрямую зависит как от типа носителя, на котором программы поставляются разработчиком, так и от типа носителя, на котором они выполняются. Иными словами, нельзя одно и то же решение с одинаковым успехом применить как к программе, поставляемой на дискетах и работающей с жесткого диска компьютера, так и к программе, поставляемой на компакт-диске и выполняемой прямо с него.

Теперь давайте последовательно рассмотрим механизмы, применяемые с целью защиты.

В начало В начало

Простая проверка поврежденного носителя

Данный механизм позволяет защитить программу от несанкционированного копирования и применения, а также выполняемые модули программы — от работы в несанкционированных условиях. Определенный участок заданного файла, не участвующего в работе программы, технологически повреждается (например, поверхность компакт-диска — на заводе лазерным лучом). Таким образом, определенный фрагмент файла становится не читаемым. Далее в выполняемый код прошиваются инструкции по проверке его наличия, чтения, сравнения его размера, соответствия количества байтов в неповрежденной его области с эталоном и т.д. В зависимости от того, корректно ли прошла проверка, можно принимать решение о дальнейшем развитии событий в исполняемом коде программы.

Достоинства: простота и быстрота реализации.

Недостатки: требуется аппаратное участие со стороны завода-производителя, достаточно зыбка и в принципе легко взламываема.

Некоторые современные средства позволяют переписать файл защиты без поврежденного фрагмента, что впоследствии позволит воспроизвести его, заменив поврежденные участки эквивалентным количеством байтов «балласта».

В начало В начало

Ограничение числа установок программы

Позволяет ограничить число установок системы на компьютер. Применяется в основном при установке программного продукта с дискет, при этом при каждой установке с дискеты «вычитывается» значение количества оставшихся установок. Применяется, как правило, в сочетании с проверкой поврежденного носителя, делая тем самым процесс копирования один в один невозможным.

Достоинства: такая защита выгодна как для разработчика, так и для пользователя программного продукта. Разработчик может распространять программный продукт по цене, зависящей от количества разрешенных инсталляций.

Недостатки: требуется аппаратное участие со стороны завода-производителя; защита не может быть применена самостоятельно (без проверки носителя на предмет наличия дефекта поверхности).

В начало В начало

Ограничение числа запусков программы (limited use copy)

Позволяет ограничить число запусков программы. При каждом запуске программы «вычитывается» значение количества оставшихся запусков.

Достоинства: обладает хорошим рекламным свойством.

Недостатки: для взлома достаточно определить место в системе (файл или системный реестр), куда заносится информация о количестве оставшихся запусков.

В начало В начало

Контрольные вопросы

Защищает выполняемые модули программы от работы в несанкционированных условиях. Как правило, срабатывает по истечении определенного срока со дня применения. Пользователю задается контрольный вопрос (вопросы), требующий наличия у него лицензионной версии программного продукта, например о надписях на поверхности компакт-диска, или слова из прилагаемой к программному обеспечению инструкции. Таким образом, может быть обеспечена привязка к поверхности компакт-диска, коробке продукта или руководству пользователя. Основной смысл здесь состоит в следующем: предположим, что потенциальному взломщику удалось запустить программу несанкционированно, тираж пиратских копий им уже подготовлен и почти распродан, и тут оказывается, что программа требует ввода третьего слова с пятнадцатой строки на последней странице справочного руководства.

Достоинства: механизм замедленного срабатывания, при удачном рассредоточении запросов по выполняемому коду защита трудновзламываема.

Недостатки: механизм не может применяться как основное средство защиты программы или обучающего курса.

В начало В начало

Временные (умирающие) версии

Защищает выполняемые модули программы от работы в несанкционированных условиях. Срабатывает по дате или по количеству запусков. Программа попросту перестает работать начиная, например, с 2000 года. Применяется в основном для создания временных, демонстрационных, так называемых «умирающих» (trial) версий. Возможно применение другого варианта, например программа перестает работать под управлением операционных систем, чьи системные файлы обновлялись позднее 2000 года (например, system.ini, win.ini, control.ini ...).

Достоинства: обеспечивает защиту в случаях, когда создание полноценной защиты в силу определенных обстоятельств невозможно. Один из самых дешевых с точки зрения производства тиража вариантов защиты (нет необходимости в сложных технологических процессах повреждения поверхности, ключевых дискетах и т.д.).

Недостатки: первый вариант попросту можно обойти, изменив системную дату, хотя это и несколько неудобно для пользователя.

В начало В начало

Версии, работающие с ограничениями

Защищает выполняемые модули программы от работы в несанкционированных условиях. Заставляет пользователя ограничиваться лишь немногими функциями или временем работы программы в одном сеансе запуска. В то же время может обладать механизмом перевода в полноценный режим. Например, при запуске генерируется уникальный для данного компьютера и совокупности программного обеспечения номер по определенному алгоритму, разнесенному в выполняемом коде. Сообщив это число компании-разработчику программного обеспечения, пользователь получает число-ответ, ввод которого раскрывает все возможности программы или снимает все временные или иные ограничения при ее работе.

Достоинства:обладает хорошим рекламным свойством. Программа в таком случае может распространяться бесплатно, например в качестве приложения к журналу или по сети Internet. Таким образом с пользователя снимается необходимость покупать «кота в мешке», а с разработчика — затраты на рекламу, доставку, телефонные разговоры или почтовые переводы.

Недостатки:при переустановке программного обеспечения компьютера потребуется повторная перерегистрация копии программы. Кроме того, в случае с ограниченными функциями тем не менее программа в принципе работает, и это может устроить некоторых пользователей.

В начало В начало

Анализ поверхности поврежденного носителя

Защищает от несанкционированного копирования и применения, а также выполняемые модули программы от работы в несанкционированных условиях. Такая защита сложна в реализации. Повторяет те же действия, что и простая проверка поврежденного носителя, однако кроме всего прочего еще и проверяет обязательное наличие физического дефекта поверхности носителя в определенном месте, делая, таким образом, механизм «взлома», описанный ранее, неприменимым.

Достоинства: защита достаточно надежна и обладает наименьшей степенью взламываемости.

Недостатки: защита сложна в реализации ввиду того, что различные устройства носителей (в частности, CD-ROM) ведут себя совершенно по-разному при попытке чтения поврежденной области. Например, подавляющее большинство устройств CD-ROM (приблизительно 85%) попросту возвращают ошибку чтения. Однако некоторые устройства зависают напрочь, что создает необходимость в реализации обходного варианта для этих случаев. Приходится искусственно отлавливать зависший процесс, например по таймеру, и «убивать» вручную, например программным открытием или закрытием лотка устройства (так как все другие методы, как правило, ни к чему не приводят) или перезагрузкой компьютера. В последнем случае, разумеется, следует позаботиться о механизме регистрации событий, фиксирующем реализацию обходного варианта и запускающем для таких устройств вспомогательную защиту, например «контрольные вопросы». Может создавать определенный дискомфорт при запуске программы (простои, перезагрузки, зависания).

В начало В начало

Аппаратные ключи (dongles)

Защищают от несанкционированного копирования и применения, а также выполняемые модули программы — от работы в несанкционированных условиях. Защищаемое программное обеспечение требует для своей работы наличия аппаратного ключа, устанавливаемого на порт принтера компьютера. Такой ключ изготавливается и распространяется вместе с программным обеспечением. Каждый ключ имеет свой уникальный серийный номер, который деблокируется при введении уникального значения для каждой копии программы. Если такой ключ программой не обнаружен, то она либо не запускается, либо запускается с ограничениями.

Достоинства: высокая надежность механизма. Все идентификационные коды, пароли, а также формулы их получения находятся не в оперативной памяти компьютера и не на жестком диске или дискете, а в микросхемах аппаратного ключа, являясь тем самым практически недоступными.

Недостатки:сложность и дороговизна реализации. Дискомфорт при работе (возможны проблемы с портом и принтером). Механизм непригоден для продаж или распространения программного обеспечения средствами Internet.

В начало В начало

Сетевая защита

Обеспечивает работу ограниченного числа зарегистрированных копий программного продукта в локальной вычислительной сети. Защита может быть реализована как контроль над числом одновременно работающих копий программы с сервера приложений или в автономном (локальном) режиме. Механизм требует наличия системы слежения за числом одновременно работающих копий и должен обеспечивать постановку пользователей в очередь с автоматическим запуском или без автоматического запуска освободившейся копии. Кроме того, разработчик приложения, желающий защитить его в локальной вычислительной сети, должен подумать и о механизме «дозакупки» рабочих мест такой системы.

Достоинства: защита полезна при разработке корпоративного продукта.

Недостатки:сложность реализации (необходимость поддержки различных протоколов локальных сетей).

В начало В начало

Немного о принятии решения

Разумеется, не следует сразу же после возврата функции проверки легальности программного продукта закрывать программу, выдав при этом гордое предупреждение о том, что защита «сработала». Целесообразнее применить метод «глобальных переменных». Суть его заключается в следующем: при запуске программы инициализируются несколько глобальных переменных, участвующих в программе во всех основных вычислениях в разных модулях, объектах и т.д. Значения этих переменных, присвоенные им по умолчанию, никак не отражаются на результатах вычислений, однако стоит защите «сработать» как сразу же эти переменные получают совершенно другие, неправильные значения, приводящие к некорректной работе программы.

Таким образом, обеспечивается временной разрыв события срабатывания защиты с событием, искажающим программу, а стало быть, с местом, в коде где в этот момент окажется предполагаемый взломщик при трассировке программы в отладчике.

Не следует также называть проверяемый на дефект поверхности файл соответствующим наводящим именем и размещать его в одноименном каталоге.

Рекомендуется заполнить файл в соответствии с его именем (например, придать ему заголовок динамической библиотеки DLL или файла справки HLP и соответствующее имя), таким образом, чтобы у предполагаемого взломщика не возникало сомнений относительно его предназначения как библиотеки, файла справки и т.п.

В начало В начало

А как же быть с данными?

Представьте себе такую картину: вы разрабатываете программный продукт, например мультимедийный CD-ROM, который помимо написанной талантливыми программистами программы, содержит массу качественного и актуального материала, например видеороликов или звуков, которые в доступной форме лежат на нем. Не правда ли обидно, ведь пользователь такого диска может использовать все его данные без искуснейшим образом защищенной программы. А если это база данных в стандартном формате (например, dbf), то тут и говорить не о чем, никому тут программа нужна не будет, ведь основная ценность такого пакета в первую очередь в данных. Ясно одно, если тот или иной программный пакет представляет собой не просто какое-то решение или прикладной инструмент, а содержит еще и актуальные данные, то встает вопрос о защите этих данных от использования независимо от программы их представления. Разумеется, речь идет лишь о стандартных форматах данных.

Предлагаемых решений, на мой взгляд, здесь может быть два: либо разработать собственный формат данных, что зачастую проблема далеко не тривиальная и в значительной степени усложнит и затянет разработку программного продукта, либо каким-нибудь образом преобразовать исходный формат так, чтобы сделать его недоступным независимо от программы. Например, видеоролик можно заархивировать с помощью алгоритма ZIP с использованием пароля, а затем распаковывать его для показа программно, непосредственно перед моментом его воспроизведения.

Перед тем как перейти к обзору существующих решений следует заметить, что рассмотренные выше механизмы используются, как правило, в комбинации друг с другом, а не по отдельности.

Обзор инструментальных комплексов и средств автоматизации построения системы защиты программного обеспечения

В начало В начало

Crypto ++ SDK 3.0

Copyright © 1997-1999 Sampson Multimedia.

Инструментальный пакет Crypto++ SDK состоит из динамических библиотек OCX, DLL, контролирующих весь процесс защиты, а также вспомогательного средства Key Calculator Wizard, позволяющего генерировать знаковые последовательности для защиты приложений.

Crypto++ SDK применяется для защиты программных продуктов методом “умирающих” версий и предназначен для их распространения с помощью Internet. При этом используются механизмы ограничений количества запусков, инсталляций и ограничения по дате работы программы. Помимо этого в арсенале Crypto++ имеются также средства по поддержке механизма привязки программного продукта к конкретному компьютеру аппаратно. Пакет содержит динамически подключаемые библиотеки, поддерживающие многие распространенные языки программирования, такие как: Visual Basic, Visual C++, Delphi, C++ Builder и Borland C++ . Поддерживается как Win32 так и Win16.

Кроме того, в Crypto ++ встроена поддержка ActiveX и Director Xtras, последняя позволяет защищать приложения, созданные с помощью Macromedia Director так называемые прожекторы (projectors).

Временные (1 год) версии средств разработки механизмов защиты программных продуктов с помощью Crypto++ SDK 3.0 можно скачать с сайта компании Sampson Multimedia. При этом Вам по почте пришлют список паролей для распаковки скаченных Вами модулей (при условии, что Вы указали свой электронный адрес во время регистрации).

В начало В начало

Gus

Gus Communications, Inc.

Инструментальный пакет Gus также представляет собой библиотеки OCX для автоматизации разработки защиты программного обеспечения. Механизм действия пакета похож на механизм действия Crypto++. Защита, реализуемая с помощью Gus Software Protection OCX полностью программная и превращает зарегистрированные копии, перенесенные на другие компьютеры во временные.

Системные требования: Windows 95/98 или Windows NT; Любой OCX (ActiveX) совместимый язык программирования (Delphi, Visual Basic, Microsoft Visual C++ и т.д.).

В начало В начало

CripKey

Kenonic Controls Ltd.

Разработчики предлагают использовать два способа защиты приложений – с помощью CripKey Software Developer Kit или программной реализации тех же функций CrypKey Instant. Программа автоматически устанавливает CrypKey в готовый EXE (как Win 16 так и Win32). Далее заботливый мастер проводит Вас, последовательно помогая выбрать необходимые опции защиты (в основном это опции ограниченной версии).

Очевидно, что использование такого простого инструмента для создания надежной защиты весьма сомнительно, это гораздо реальнее сделать с помощью SDK предоставляемого разработчиком.

Основной отличительной особенностью CrypKey является то, что он позволяет передавать зарегистрированную версию от компьютера к компьютеру, деинсталлируя при этом версию-исходник.

Помимо этого, CrypKey может контролировать использование программного продукта в локальной вычислительной сети. Это означает, что если пользователь заплатил за 5 копий программного продукта, то 6-я копия с сервера приложений в локальной сети не запуститься. Реализованная система не зависит от используемого протокола (IPX, NetBios или WinSockets). Примечательно еще то, что при защите программного продукта средствами CriptKey нет необходимости в разработке множества выполняемых модулей для поддержки различных платформ и сетевых протоколов. Система снабжена автоматическим менеджером очереди приложений, который уведомляет пользователей очереди об освободившейся копии.

В начало В начало

Microcosm Copy Protection

Microcosm Copy Protection

Из всего спектра программных решений по защите, разрабатываемых компанией, рассмотрим два следующих:

UnLock-It

Программа позволяет реализовать механизм ограниченных версий и не требует наличия дополнительных аппаратных средств (дискет или аппаратных ключей). Обладает возможностью сетевой защиты и антивирусной защиты выполняемых модулей. UnLock-It поддерживает режим так называемого найма приложений, при котором пользователь может «заказать» определенное количество запусков или определенное время работы приложения. UnLock-It совместим с операционными системами: старше MS-DOS 2.0, PC DOS или Novell DOS, Concurrent DOS, Windows 3.x, NT и с сетями DOS или Windows (включая Novell).

В начало В начало

Dinkey Dongles

Реализует механизм аппаратного ключа, используя для этого порт принтера.

Поддерживает четыре режима Dinkey Dongle: Dinkey 1, Dinkey 1S, Dinkey 2 и Dinkey Net.

Dinkey 1: уникальный серийный номер, присвоенный аппаратному ключу, позволяет защитить лишь одно приложение;

Dinkey 1S: серии аппаратных ключей присваивается один и тот же серийный номер. Таким образом, разработчик может тиражировать программное обеспечение без его индивидуализации, для использования с определенным аппаратным ключом;

Dinkey 2: позволяет реализовать временные или ограниченные версии на базе аппаратного ключа, а также одновременную защиту до 17 приложений. Имеет возможность дистанционно изменять параметры защиты.

Dinkey Net: представляет собой сетевую версию аппаратного ключа Dinkey 2. При установке в локальной вычислительной сети реализует механизм сетевой защиты. Имеет возможность дистанционно изменять параметры защиты.

В начало В начало

PC Guard

Copyright © by Blagoje Ceklic

Инструментальный пакет PC Guard представляет собой систему защиты программных продуктов, позволяющую полностью автоматизировать этот процесс. PC Guard достаточно прост в обращении. Принцип его работы заключается в том, что вокруг защищаемой программы создается этакий конверт, защищающий ее от анализа потенциальным взломщиком или копирования с одного компьютера на другие. Замечательно то, что PC Guard легко комбинируется с любым другим механизмом защиты. Кроме того, в PC Guard для Win32 встроена функция защиты приложения паролем. Защитить можно непосредственно модули EXE или DLL. Этот механизм не требует встраивания библиотек в код защищаемого программного продукта, обеспечивая, таким образом, поддержку практически любого языка программирования. Защитный конверт состоит из нескольких защитных слоев, каждый из которых реализует соответствующую задачу (защита от анализа выполняемых модулей, защита с использованием механизмов ограничений, защита паролем).

PC Guard позволяет обеспечить привязку защищаемого программного продукта к аппаратуре компьютера, а именно: к жесткому диску, к дате BIOS и к установленной операционной системе. PC Guard работает под управлением операционных систем DOS,Windows 3.x (Win16) и Windows 95/98/NT (Win32).

В начало В начало

SafeSerial OCX для Windows 95, 98, NT, 2000

Sikander Soft Inc.

Еще один инструмент для разработчиков, позволяющий автоматизировать процесс защиты программного продукта.

Поддерживает создание ключевых дискет, временных и ограниченных версий продукта, настраивается для контроля за сетевыми версиями, а также снабжен механизмом «перемещения лицензии» с одного жесткого диска на другой, что довольно-таки удобно.

Следует отметить, что отличительной особенностью библиотек OCX по сравнению со стандартными DLL является максимальная простота встраивания в код разрабатываемой программы. Необходимо всего лишь «перетащить» компонент управления на основную «форму» защищаемого приложения. Наглядным примером тому служит SafeSerial OCX. Добавьте к этому еще и набор всевозможных стандартных сообщений и диалоговых окон на 8 различных языках.

Библиотека поддерживает языки программирования Delphi (только Win32) , Visual Basic, C++ Builder и другие, поддерживающие механизм ActiveX. Для получения более детальных сведений о работе системы разработчики советуют прочитать руководство по использованию SafeSerial OCX.

В начало В начало

Wibu — Key

©1999 Copy-Protection.com.

Компания ©1999 Copy-Protection.com разработала и реализовала механизм аппаратного ключа в своем продукте WIBU-KEY Copy Protection System. Основной областью применения разработанной технологии выбрана защита программ, работающих в вычислительных сетях.

Аппаратные ключи разрабатываются на базе чипов ASIC (Application Specific Integrated Circuit) и совместимы с персональными компьютерами как PC так и Macintosh.

В начало В начало

Lock & Key

Timeless Technologies, Inc.

Lock & Key разработан для платформ Windows 3.x, 95/98, NT и полностью совместим с Delphi версий 1, 2, 3, 4. Представляет собой достаточно простую реализацию стандартных алгоритмов по созданию временных или ограниченных версий программных продуктов.

В начало В начало

Windows Protection Tool-Kit™

Advanced Software Technologies

Инструментальный пакет Windows Protection Tool-Kit™ работает под управлением Windows 3.x, 95/98, NT. Оснащен механизмом привязки к ключевой дискете, работающим, правда, только под управлением Windows NT. Может защищать программы для работы в локальных сетях на базе Windows NT, Lantastic или Novell. Защищаемые приложения могут привязываться к жесткому диску или к локальной сети. По желанию можно создавать версии с ограничением количества инсталляций, и даже умеющие возвращать количество инсталляций при деинсталляции защищенного программного продукта.

Однако система защищает программный продукт лишь на стадии его установки (setup).

Пакет Windows Protection Tool-Kit™ совместим с такими известными пакетами автоматизации создания инсталляций, как Install Shield и Visual Basic's Setup Wizard, а разрабатывался он для WISE Installation System.

В начало В начало

Sheriff

Acudata Limited

Инструментальный комплекс Sheriff предлагает еще одно средство разработки механизма программной защиты приложений (временных и ограниченных версий) – Sheriff Software Development Kit (SDK) для Win32.

Sheriff представлен пользователю достаточно гибким набором библиотек: как стандартной Windows DLL, так и компонентом ActiveX (OCX control).

В отличие от решений, рассмотренных ранее, API системы Sheriff предлагает самостоятельно настроить все характеристики создаваемой версии программного продукта, а не заполнить поля в стандартном диалоговом окне. Предлагаемый SDK достаточно гибок и включает классы и демонстрационные примеры на различных языках с использованием разнообразных технологий: Visual C++, Visual Basic, Visual FoxPro и Delphi, а также ActiveX Сontrol.

Следует отметить, что Sheriff обладает достаточно большим набором механизмов защиты от резидентного мониторинга, трассировки в отладчиках или перестановки системной даты или дат изменения различных системных файлов.

В начало В начало

Hardlock Bistro

Aladdin Knowledge Systems GmbH & Co.

Компания Aladdin разработала Hardlock Bistro – целую серию средств для защиты приложений. Aladdin предлагает наиболее полный набор средств автоматизации защиты приложений, входящих в состав Hardlock Bistro: Espresso Wizard, Espresso, Cappuccino и Lattecino, и девять различных аппаратных привязок для обеспечения функционирования разных механизмов аппаратных зависимостей.

Этакий интерфейс самого высокого уровня между собственно модулем Hardlock и защищаемой программой. Чуть «ниже» располагается следующий модуль – программа Espresso, позволяющая защищать программы в автоматизированном режиме, а для любителей программировать Aladdin предлагает реализацию API – Lattecino. В любом случае Hardlock Bistro заботливо проведет Вас последовательно по всем этапам создания защиты.

Немного о специфике рынка

Рассмотрев различные средства автоматизации процесса защиты программных продуктов, мы видим, что все они в основном принадлежат к двум классам:

системы, предназначенные для создания временных или ограниченных копий;

системы с аппаратными ключами защиты;

Первые предназначены в основном для распространения программ через мировую компьютерную сеть Internet и давно уже получили широкое распространение во всем мире, вторые – для создания пусть дорогих, но весьма надежно защищенных программ. Следует отметить, что в последнем случае может оказаться, что стоимость аппаратного ключа окажется больше стоимости защищаемого программного продукта.

В то же время, как показывает практика, многие отечественные пользователи предпочитают применять ограниченные или временные версии программ, вместо того чтобы покупать полные.

Альтернативой этим двум системам являются системы защиты с анализом поверхности поврежденного носителя. И хотя такие системы неприемлемы для распространения программы средствами Internet, но довольно-таки надежны.

Все рассмотренные системы различаются как по реализуемым механизмам защиты, так и по надежности. Весь вопрос в том, какую систему применять для защиты того или иного программного продукта. Здесь имеет место взаимосвязь игра-свечи как для потенциального взломщика, так и для потенциального покупателя.

И в заключение

Несколько полезных ссылок для разработчиков:

Много разнообразных полезных инструментов в помощь разработчикам как прикладного, так и системного программного обеспечения вы найдете на http://computer.org/computer/tools/sof-toc.htm

Сайт рейтингов различных программ и инструментальных пакетов находится на сайте http://topsoft.com/.

Советую также заглянуть на сайт http://www.winfiles.com/.

КомпьютерПресс 11'1999