Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Deck of Cards
id001
Card
defaulttrue
labelC
Code Block
languagecpp
int GRD_API  GrdSign(
  HANDLE hGrd,			
  DWORD	dwAlgoNum,		
  DWORD	dwDataLng,		
  void	*pData,			
  DWORD	dwSignResultLng,
  void	*pSignResult,	
  void	*pReserved
   );	
Expand
titleПараметры функции

hGrd

хэндл, через который будет выполнена данная операция

dwAlgoNum

числовое имя аппаратного алгоритма типа ECC Algorithm

dwDataLng

длина массива данных (20 байтов для ECC160)

pData

указатель на массив данных

dwSignResultLng

длина массива цифровой подписи (40 байтов для ECC160)

pSignResult

указатель на массив цифровой подписи

pReserved

зарезервировано

Expand
titleВозвращаемое значение функции

GrdE_OK

нет ошибок

GrdE_NeedInitialization

требуется инициализация API (вызов GrdStartup)

GrdE_InvalidHandle

недействительный хэндл

GrdE_InvalidArg

недопустимый параметр при вызове функции

GrdE_NoService

ключ не поддерживает данную функцию

GrdE_AlgoNotFound

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

GrdE_CRCErrorFunc

ошибка CRC при выполнении функции

GrdE_GPis0

счетчик алгоритма достиг нулевого значения

Expand
titleОписание

Функция GrdSign позволяет вычислять цифровую подпись массива данных при помощи аппаратного алгоритма типа ECC. Вычисление цифровой подписи выполняется алгоритмом с числовым именем, заданным в параметре dwAlgoNum. Этот алгоритм предварительно должен быть создан, в противном случае возвращается ошибка GrdE_AlgoNotFound. Если в дескрипторе алгоритма установлен флаг "уменьшение счетчика", то вычитание счетчика алгоритма происходит при каждом вызове GrdSign. При достижении счетчиком нулевого значения, возвращается ошибка GrdE_GPis0. Если при создании алгоритма или в процессе работы он был переведен в неактивное состояние, возвращается ошибка GrdE_InactiveItem.

Если в дескрипторе алгоритма установлен флаг nsafl_GP_dec (уменьшение счетчика), вычитание счетчика GP происходит при каждом вызове GrdSign.

Длина массива данных (в байтах) pData задается параметром dwDataLng и зависит от типа алгоритма.

Длина возвращаемой цифровой подписи (в байтах) pSignResult также зависит от типа алгоритма и задаётся параметром dwSignResultLng.

Длина буфера данных задаётся параметром dwDataLng. Сам буфер данных должен находиться по адресу, указанному в параметре pData. Возвращаемая цифровая подпись находится по адресу pSignResult и имеет длину dwSignResultLng. Для алгоритма ECC160 длина массива данных и длина возвращаемой цифровой подписи должны быть  GrdECC160_MESSAGE_SIZE (20 байт) и GrdECC160_DIGEST_SIZE (40 байт) соответственно.

Card
labelC#
Code Block
languagec#
public static GrdE GrdSign(Handle grdHandle, GrdAlgNum algNum, byte[] data, out byte[] digestSign)
Expand
titleПараметры метода

grdHandle [in] 

Тип: Handle

хэндл, через который будет выполнена данная операция.

algNum [in]

Тип: GrdAlgNum

Числовое имя аппаратного алгоритма.

data [in] 

Тип: byte [ ]

Указатель на массив данных.

digestSign [out] 

Тип: byte [ ]

Указатель на массив цифровой подписи.

Expand
titleВозвращаемое значение метода

GrdE.OK

нет ошибок

GrdE.NeedInitialization

требуется инициализация API (вызов GrdStartup)

GrdE.InvalidHandle

недействительный хэндл

GrdE.InvalidArg

недопустимый параметр при вызове функции

GrdE.NoService

ключ не поддерживает данную функцию

GrdE.AlgoNotFound

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

GrdE.CRCErrorFunc

ошибка CRC при выполнении функции

GrdE.GPis0

счетчик алгоритма достиг нулевого значения

Expand
titleОписание

Метод GrdSign позволяет вычислять цифровую подпись массива данных при помощи аппаратного алгоритма типа ECC. Вычисление цифровой подписи производится алгоритмом с числовым именем, заданным в параметре algNum. Этот алгоритм предварительно должен быть создан.

Если в дескрипторе алгоритма установлен флаг nsafl_GP_dec (уменьшение счетчика), вычитание счетчика GP происходит при каждом вызове GrdSign.

Длина массива данных (в байтах) data  зависит от типа алгоритма.

Для алгоритма ECC160 длина массива данных и длина возвращаемой цифровой подписи digestSign должны быть GrdECC160.MESSAGE_SIZE (20 байт) и   GrdECC160_DIGEST_SIZE (40 байт) соответственно.

Card
labelJava
Code Block
languagejava
 public static GrdE GrdSign(Handle grdHandle, int algNum, byte[] data, byte[] sign)
Expand
titleПараметры метода

grdHandle [in] 

Тип: Handle

хэндл, через который будет выполнена данная операция.

algNum [in]

Тип: int

Числовое имя аппаратного алгоритма.

data [in] 

Тип: byte [ ]

Указатель на массив данных.

sign [out] 

Тип: byte [ ]

Указатель на массив цифровой подписи.

Expand
titleВозвращаемое значение метода

GrdE.OK

нет ошибок

GrdE.NeedInitialization

требуется инициализация API (вызов GrdStartup)

GrdE.InvalidHandle

недействительный хэндл

GrdE.InvalidArg

недопустимый параметр при вызове функции

GrdE.NoService

ключ не поддерживает данную функцию

GrdE.AlgoNotFound

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

GrdE.CRCErrorFunc

ошибка CRC при выполнении функции

GrdE.GPis0

счетчик алгоритма достиг нулевого значения

Expand
titleОписание

Метод GrdSign позволяет вычислять цифровую подпись массива данных при помощи аппаратного алгоритма типа ECC. Вычисление цифровой подписи производится алгоритмом с числовым именем, заданным в параметре algNum. Этот алгоритм предварительно должен быть создан.

Если в дескрипторе алгоритма установлен флаг nsafl_GP_dec (уменьшение счетчика), вычитание счетчика GP происходит при каждом вызове GrdSign.

Длина массива данных (в байтах) data  зависит от типа алгоритма.

Для алгоритма ECC160 длина массива данных и длина возвращаемой цифровой подписи sign должны быть GrdECC160.MESSAGE_SIZE (20 байт) и GrdECC160.DIGEST_SIZE (40 байт) соответственно.