You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 7 Next »

Описание

Шифрует буфер данных при помощи криптографического алгоритма AES128 ассоциированного с компонентом (Feature). Выполняет проверку лицензионный условий компонента.

Если лицензия ограничена по количеству запусков, то эта функция уменьшает значение счетчика запусков для лицензии.

Если установлен флаг GRD_NO_COUNTER_DECREMENT, то эта функция использует другой ключ шифрования и счетчик запусков не уменьшается.

По умолчанию используется режим шифрования GRD_EM_ECB. 

Результаты шифрования одинаковых данных с флагом GRD_NO_COUNTER_DECREMENT и без него будут различаться

Если при шифровании использовался вектор инициализации iv, то при расшифровке необходимо указать тот же вектор

Синтаксис

int GRD_API GrdFeatureEncrypt(GrdHandle handle, 
							  grd_uint32 dataSize, 
							  void* data, 
							  grd_uint32 mode, 
							  void* context, 
							  grd_uint32 contextSize);

Параметры

handle
Дескриптор сеcсии
dataSize
Размер (в байтах) буфера на открытое сообщение
data
Указатель на буфер содержащий открытое сообщение
mode

Режим шифрования:

  • GRD_EM_ECB
  • GRD_EM_CBC
  • GRD_EM_CFB 
  • GRD_EM_OFB

Флаги шифрования:

  • GRD_NO_COUNTER_DECREMENT
  • GRD_SOFTWARE_ACCELERATION
context
Указатель на контекcт, необходимый для операций шифрования с помощью AES. Может быть NULL
contextSize
Размер контекста. Должен быть равен sizeof(GrdAesContext). Может быть 0

Возвращаемые значения

GRD_OK

GRD_INVALID_HANDLE

GRD_INVALID_FEATURE


  • No labels