Подпись и проверка подписи
Описание и примеры представлены в разделе Работа с электронной подписью.
signData
GOST
PRO
PKI
- signData
Подписать данные.
Возвращает подпись в формате PKCS#7.
Передавать на подпись можно либо данные (аргумент data), либо имя файла (аргумент fileName).
Если одновременно передать аргументы data и fileName, то fileName игнорируется.
Текущее состояние аутентификации можно получить с помощью команды
getLoggedInState.
Примеры в разделе Формирование электронной подписи.
- Аргументы:
Примечание
Значение идентификатора не постоянно, но в рамках сессии не меняется.
attachedSignature (По-умолчанию: false
)
Тип: Boolean
Включать ли данные в подпись PKCS#7 (true
- включать).
Примечание
Если установлен в true
и подписываются данные из файла (аргумент fileName),
то будет сгенерировано исключение.
Примечание
Если установлен аргумент signature, то значение attachedSignature игнорируется.
useHardwareHash (По-умолчанию: false
)
Тип: Boolean
Признак использования аппаратного хэширования.
data (Необязательный)
Тип: Array
Данные для подписи в виде массива байт.
fileName (Необязательный)
Тип: String
Имя файла, содержимое которого требуется подписать.
Примечание
Если аргумент data установлен, то fileName игнорируется.
signature (Необязательный)
Тип: Array
Подпись в виде массива байт в формате PKCS#7. Используется для создания множественной подписи.
Если signature является отсоединенной подписью, то необходимо наличие аргументов data или fileName.
Если signature является присоединенной подписью, то данные для подписи извлекаются из signature, если отсутствуют аргументы data или fileName.
userHostData (Необязательный)
Тип: Array
Список получаемых данных с пользовательского ПК,
которые будут подписаны и войдут в результирующий PKCS#7 конверт.
Массив должен содержать строки из
JCWebClient2.Vars.UserHostData
.
Примечание
Информация о системе представляет собой строку в формате JSON. Она добавляется в подпись как подписываемый атрибут (signed attribute). OID атрибута: 1.2.643.2.7.1.1.1.
customSignedAttributes (Необязательный)
Тип: Array
Массив с пользовательскими подписываемыми атрибутами.
- Каждый элемент массива является объектом с параметрами:
oid
Тип: String
OID атрибута.
value
Тип: String
Значение атрибута.
addSigningTime (По-умолчанию: false
)
Тип: Boolean
Включать в подпись время подписания
Время подписания добвляется в PKCS#7-контенер как атрибут с OID 1.2.840.113549.1.9.5.
Если при подписи передаются подписываемые аттрибуты (customSignedAttributes), то время подписания включается автоматически.
- Результат:
Array – массив байт с подписью в формате PKCS#7.
signDataPack
GOST
PRO
PKI
- signDataPack
Подписать несколько пакетов данных.
Возвращает массив подписей в формате PKCS#7.
Передавать на подпись можно либо массив данных (аргумент data), либо массив имён файлов (аргумент fileName).
Если одновременно передать аргументы data и fileName, то fileName игнорируется.
Текущее состояние аутентификации можно получить с помощью команды
getLoggedInState.
Примеры в разделе Формирование электронной подписи.
- Аргументы:
Примечание
Значение идентификатора не постоянно, но в рамках сессии не меняется.
attachedSignature (По-умолчанию: false
)
Тип: Boolean
Включать ли данные в подпись PKCS#7 (true
- включать).
Примечание
Если установлен в true
и подписываются данные из файла (аргумент fileName),
то будет сгенерировано исключение.
Примечание
Если установлен аргумент signature, то значение attachedSignature игнорируется.
useHardwareHash (По-умолчанию: false
)
Тип: Boolean
Признак использования аппаратного хэширования.
data (Необязательный)
Тип: Array
Данные для подписи в виде массива массивов байт.
fileName (Необязательный)
Тип: Array
Массив имён файлов, содержимое которых требуется подписать.
Примечание
Если аргумент data установлен, то fileName игнорируется.
signature (Необязательный)
Тип: Array
Подпись в виде массива байт в формате PKCS#7. Используется для создания множественной подписи.
Если signature является отсоединенной подписью, то необходимо наличие аргументов data или fileName.
Если signature является присоединенной подписью, то данные для подписи извлекаются из signature, если отсутствуют аргументы data или fileName.
userHostData (Необязательный)
Тип: Array
Список получаемых данных с пользовательского ПК,
которые будут подписаны и войдут в результирующий PKCS#7 конверт.
Массив должен содержать строки из
JCWebClient2.Vars.UserHostData
.
Примечание
Информация о системе представляет собой строку в формате JSON. Она добавляется в подпись как подписываемый атрибут (signed attribute). OID атрибута: 1.2.643.2.7.1.1.1.
customSignedAttributes (Необязательный)
Тип: Array
Массив с пользовательскими подписываемыми атрибутами.
- Каждый элемент массива является объектом с параметрами:
oid
Тип: String
OID атрибута.
value
Тип: String
Значение атрибута.
addSigningTime (По-умолчанию: false
)
Тип: Boolean
Включать в подпись время подписания
Время подписания добвляется в PKCS#7-контенер как атрибут с OID 1.2.840.113549.1.9.5.
Если при подписи передаются подписываемые аттрибуты (customSignedAttributes), то время подписания включается автоматически.
- Результат:
Array – массив массивов байт с подписями в формате PKCS#7. Количество возвращаемых подписей и их порядок соответствуют количеству и порядку массивов передаваемых данных (data) или имён файлов (fileName).
signBase64EncodedData
GOST
PRO
PKI
- signBase64EncodedData
Подписать данные.
Возвращает подпись в формате PKCS#7, закодированную в Base64.
Передавать на подпись можно либо данные (аргумент data), либо имя файла (аргумент fileName).
Если одновременно передать аргументы data и fileName, то fileName игнорируется.
Текущее состояние аутентификации можно получить с помощью команды
getLoggedInState.
Примеры в разделе Формирование электронной подписи.
- Аргументы:
Примечание
Значение идентификатора не постоянно, но в рамках сессии не меняется.
attachedSignature (По-умолчанию: false
)
Тип: Boolean
Включать ли данные в подпись PKCS#7 (true
- включать).
Примечание
Если установлен в true
и подписываются данные из файла (аргумент fileName),
то будет сгенерировано исключение.
Примечание
Если установлен аргумент signature, то значение attachedSignature игнорируется.
useHardwareHash (По-умолчанию: false
)
Тип: Boolean
Признак использования аппаратного хэширования.
data (Необязательный)
Тип: String
Данные для подписи в виде строки, закодированной в Base64.
fileName (Необязательный)
Тип: String
Имя файла, содержимое которого требуется подписать.
Примечание
Если аргумент data установлен, то fileName игнорируется.
signature (Необязательный)
Тип: String
Подпись в формате PKCS#7, закодированная в Base64. Используется для создания множественной подписи.
Если signature является отсоединенной подписью, то необходимо наличие аргументов data или fileName.
Если signature является присоединенной подписью, то данные для подписи извлекаются из signature, если отсутствуют аргументы data или fileName.
userHostData (Необязательный)
Тип: Array
Список получаемых данных с пользовательского ПК,
которые будут подписаны и войдут в результирующий PKCS#7 конверт.
Массив должен содержать строки из
JCWebClient2.Vars.UserHostData
.
Примечание
Информация о системе представляет собой строку в формате JSON. Она добавляется в подпись как подписываемый атрибут (signed attribute). OID атрибута: 1.2.643.2.7.1.1.1.
customSignedAttributes (Необязательный)
Тип: Array
Массив с пользовательскими подписываемыми атрибутами.
- Каждый элемент массива является объектом с параметрами:
oid
Тип: String
OID атрибута.
value
Тип: String
Значение атрибута.
addSigningTime (По-умолчанию: false
)
Тип: Boolean
Включать в подпись время подписания
Время подписания добвляется в PKCS#7-контенер как атрибут с OID 1.2.840.113549.1.9.5.
Если при подписи передаются подписываемые аттрибуты (customSignedAttributes), то время подписания включается автоматически.
- Результат:
String – подпись в формате PKCS#7, закодированная в Base64.
signBase64EncodedDataPack
GOST
PRO
PKI
- signBase64EncodedDataPack
Подписать несколько пакетов данных.
Возвращает массив подписей в формате PKCS#7, закодированных в Base64.
Передавать на подпись можно либо массив данных (аргумент data), либо массив имён файлов (аргумент fileName).
Если одновременно передать аргументы data и fileName, то fileName игнорируется.
Текущее состояние аутентификации можно получить с помощью команды
getLoggedInState.
Примеры в разделе Формирование электронной подписи.
- Аргументы:
Примечание
Значение идентификатора не постоянно, но в рамках сессии не меняется.
attachedSignature (По-умолчанию: false
)
Тип: Boolean
Включать ли данные в подпись PKCS#7 (true
- включать).
Примечание
Если установлен в true
и подписываются данные из файла (аргумент fileName),
то будет сгенерировано исключение.
Примечание
Если установлен аргумент signature, то значение attachedSignature игнорируется.
useHardwareHash (По-умолчанию: false
)
Тип: Boolean
Признак использования аппаратного хэширования.
data (Необязательный)
Тип: Array
Данные для подписи в виде массива строк, закодированных в Base64.
fileName (Необязательный)
Тип: Array
Массив имён файлов, содержимое которых требуется подписать.
Примечание
Если аргумент data установлен, то fileName игнорируется.
signature (Необязательный)
Тип: String
Подпись в формате PKCS#7, закодированная в Base64. Используется для создания множественной подписи.
Если signature является отсоединенной подписью, то необходимо наличие аргументов data или fileName.
Если signature является присоединенной подписью, то данные для подписи извлекаются из signature, если отсутствуют аргументы data или fileName.
userHostData (Необязательный)
Тип: Array
Список получаемых данных с пользовательского ПК,
которые будут подписаны и войдут в результирующий PKCS#7 конверт.
Массив должен содержать строки из
JCWebClient2.Vars.UserHostData
.
Примечание
Информация о системе представляет собой строку в формате JSON. Она добавляется в подпись как подписываемый атрибут (signed attribute). OID атрибута: 1.2.643.2.7.1.1.1.
customSignedAttributes (Необязательный)
Тип: Array
Массив с пользовательскими подписываемыми атрибутами.
- Каждый элемент массива является объектом с параметрами:
oid
Тип: String
OID атрибута.
value
Тип: String
Значение атрибута.
addSigningTime (По-умолчанию: false
)
Тип: Boolean
Включать в подпись время подписания
Время подписания добвляется в PKCS#7-контенер как атрибут с OID 1.2.840.113549.1.9.5.
Если при подписи передаются подписываемые аттрибуты (customSignedAttributes), то время подписания включается автоматически.
- Результат:
Array – массив подписей в формате PKCS#7, закодированных в Base64. Количество возвращаемых подписей и их порядок соответствуют количеству и порядку строк передаваемых данных (data) или имён файлов (fileName).
signHash
GOST
PRO
PKI
- signHash
Подписать данные без хэширования (т.е. подписать хэш).
Возвращает подпись в формате PKCS#7.
Текущее состояние аутентификации можно получить с помощью команды
getLoggedInState.
- Аргументы:
Примечание
Значение идентификатора не постоянно, но в рамках сессии не меняется.
hash
Тип: Array
Хэш в виде массива байт.
Примечание
Длина должна быть равна:
- GOST – 32 байта.
- PRO – 20 байт.
- GOST 2 – 32 байта.
signature (Необязательный)
Тип: Array
Подпись в виде массива байт в формате PKCS#7. Используется для создания множественной подписи.
base64Encoded (По-умолчанию: true
)
Тип: Boolean
Признак кодирования результата в Base64
(true
- вернуть строку с подписью в формате PKCS#7, закодированную в Base64).
- Результат:
- Если аргумент base64Encoded был равен
true
:
- String – строка с подписью в формате PKCS#7, закодированная в Base64.
- Если аргумент base64Encoded был равен
false
:
- Array – массив байт с подписью в формате PKCS#7
signDataInByte
- signDataInByte
Подписать данные.
Возвращает подпись в виде массива байт.
- Результат:
Array – массив байт с подписью.
signHashInByte
GOST
PRO
PKI
- signHashInByte
Подписать данные без хэширования (т.е. подписать хэш).
Текущее состояние аутентификации можно получить с помощью команды
getLoggedInState.
- Аргументы:
Примечание
Значение идентификатора не постоянно, но в рамках сессии не меняется.
hash
Тип: Array
Данные для подписи в виде массива байт.
Примечание
Длина должна быть равна:
- GOST – 32 байта.
- PRO – 20 байт.
- GOST 2 – 32 байта.
- Результат:
Array – массив байт с подписью.
verifyBase64EncodedData
- verifyBase64EncodedData
Проверить подпись PKCS#7 с данными и подписью, закодированными в Base64.
Примеры в разделе Проверка электронной подписи.
- Результат:
Boolean – результат проверки.
verifyDataInByte
- verifyDataInByte
Проверить подпись в виде массива байт.
- Результат:
Boolean – результат проверки.
verifyHashInByte
GOST
PRO
GOST 2
PKI
- verifyHashInByte
Проверить подпись хэша в виде массива байт.
Работает при любом состоянии аутентификации.
- Аргументы:
signature
Тип: Array
Массив байт с подписью.
hash
Тип: Array
Хэш данных в виде массива байт.
Примечание
Длина должна быть равна:
- GOST – 32 байта.
- PRO – 20 байт.
- GOST 2 – 32 байта.
publicKey
Тип: Array
Массив байт с публичным ключем.
- Результат:
Boolean – результат проверки.
digest
GOST
PRO
PKI
- digest
Посчитать хэш от данных.
Текущее состояние аутентификации можно получить с помощью команды
getLoggedInState.
Примечание
Алгоритм вычисления хэш-функции:
- GOST – GOST R 34.11-94;
- PRO – SHA-1.
- PKI – SHA-1.
- Аргументы:
data
Тип: Array
Массив байт с данными для хэширования.
useHardwareHash (По-умолчанию: false
)
Тип: Boolean
Признак использования аппаратного хэширования.
tokenID (Необязательный)
Тип: Integer
Идентификатор токена. Получается с помощью команды
getAllSlots.
Примечание
Значение идентификатора не постоянно, но в рамках сессии не меняется.
- Результат:
Array – результаты работы хэш-функции.