Page tree

Versions Compared

Key

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

...

Модель РутокенЗначение  slotDescription структуры CK_SLOT_INFOЗначение  model структуры CK_TOKEN_INFO
Рутокен SAktiv Co. ruToken 0Rutoken S 64K, где 64K - размер памяти
Рутокен LiteAktiv Rutoken lite 0Rutoken lite
Рутокен ЭЦПAktiv Rutoken ECP 0Rutoken ECP
Рутокен PINPadAktiv Rutoken PINPad 2 0Rutoken PINPad 2
Рутокен WebAktiv Rutoken Web 0Rutoken Web

Более удобным способом получить информацию о подключенном к слоту токене можно с помощью функции расширения C_EX_GetTokenInfoExtended(), которая возвращает расширенные данные в виде структуры типа CK_TOKEN_INFO_EXTENDED. Поля ulTokenClass и ulTokenType содержат информацию о классе и типе устройства соответственно и могут быть использованы для их определения. 

Code Block
languagecpp
titleОпределение класса токена
CK_C_EX_GetFunctionListExtended pfGetFunctionListEx = NULL_PTR; 	// Указатель на функцию C_EX_GetFunctionListExtended
CK_FUNCTION_LIST_EXTENDED_PTR 	pFunctionListEx = NULL_PTR;       	// Указатель на список функций расширения PKCS#11, хранящийся в структуре CK_FUNCTION_LIST_EXTENDED
CK_TOKEN_INFO_EXTENDED			tokenInfoEx;                        // Структура данных типа CK_TOKEN_INFO_EXTENDED с информацией о токене
 
while(TRUE)
{
	...
 
	printf("Determining token type");
 
	/* Получить адрес функции запроса структуры с указателями на функции расширения */
	pfGetFunctionListEx = (CK_C_EX_GetFunctionListExtended)GetProcAddress(hModule,
				                                                          "C_EX_GetFunctionListExtended");
	if (pfGetFunctionListEx == NULL_PTR)
	{
		printf(" -> Failed\n");
		break;
	}
 
	/* Получить структуру с указателями на функции расширения */
	rv = pfGetFunctionListEx(&pFunctionListEx);
	if (rv != CKR_OK)
	{
		printf(" -> Failed\n");
		break;
	}
	memset(&tokenInfoEx,
	   		0,
	  		sizeof(CK_TOKEN_INFO_EXTENDED));
	tokenInfoEx.ulSizeofThisStructure = sizeof(CK_TOKEN_INFO_EXTENDED);
	/* Получить расширенную информацию о подключенном токене */
	rv = pFunctionListEx->C_EX_GetTokenInfoExtended(aSlots[0],		// Идентификатор слота, к которому подключен токен
			                                   		&tokenInfoEx);	// Буфер для помещения информации о токене
	if (rv != CKR_OK)
	{
		printf(" -> Failed\n");
		break;
	}
	/* Определить класс токена */
	switch (tokenInfoEx.ulTokenClass)
	{
		case TOKEN_CLASS_S: 
			printf(": Rutoken / Rutoken S\n");
		case TOKEN_CLASS_ECP:
			printf(": Rutoken ECP\n");
		case TOKEN_CLASS_LITE:
			printf(": Rutoken Lite\n");
		case  TOKEN_CLASS_WEB:
			printf(": Rutoken WEB\n");
		case TOKEN_TYPE_RUTOKEN_PINPAD_FAMILY:
			printf(": Rutoken PINPad\n");
		default:
			printf(": undefined\n");
	}

	break;
}

...

Количество строк в документе (пар значений <N>, <V> и значений <T>) не может превышать 230, число символов в одной строке не может превышать 50.

Пример сообщения в формате PINPADFILE 

Code Block
languagecpp
titleИсходное платежное поручение в текстовом виде
ФИО: Петров Петр Петрович Москва, Пионерская ул, д. 3, кв. 72
Перевод со счета : 42301810001000075212
Сумма : 150000
Валюта : RUR
Наименование получателя : Иванова Елена Ивановна
Номер счета получателя : 40817810338295201618
БИК банка получателя : 044525225
Наименование банка получателя : ОАО 'СБЕРБАНК РОССИИ' Г. МОСКВА
Номер счета банка получателя : 30101810400000000225
Назначение платежа : перевод личных средств


Code Block
languagecpp
titleПлатежное поручение в формате PINPADFILE
<!PINPADFILE RU>
<N>ФИО:<V>Петров Петр Петрович Москва, Пионерская ул, д. 3, кв. 72
<N>Перевод со счета:<V>42301810001000075212
<N>Сумма:<V>150000
<N>Валюта:<V>RUR
<N>Наименование получателя:<V>Иванова Елена Ивановна
<N>Номер счета получателя:<V>40817810338295201618
<N>БИК банка получателя:<V>044525225
<N>Наименование банка получателя:<V>ОАО 'СБЕРБАНК РОССИИ' Г. МОСКВА
<N>Номер счета банка получателя:<V>30101810400000000225
<N>Назначение платежа:<V>перевод личных средств

Чтобы данные были корректно распознаны Рутокен PINPad, они должны быть представлены в виде строки с однобайтовыми символами, соответствующими кодировке Windows-1251 или UTF-8.

Code Block
languagecpp
titleДанные в формате PINPADFILE для подписи с отображением в кодировке Windows-1251
char PINPADFILECP1251[] = 	"<!PINPADFILE RU><N>ФИО:<V>Петров Петр Петрович Москва, Пионерская ул, д. 3, кв. 72"\
	                		"<N>Перевод со счета:<V>42301810001000075212<N>Сумма:<V>150000<N>Валюта:<V>RUR"\
							"<N>Наименование получателя:<V>Иванова Елена Ивановна<N>Номер счета получателя:<V>40817810338295201618"\
							"<N>БИК банка получателя:<V>044525225<N>Наименование банка получателя:<V>ОАО 'СБЕРБАНК РОССИИ' Г. МОСКВА"\
							"<N>Номер счета банка получателя:<V>30101810400000000225<N>Назначение платежа:<V>перевод личных средств";


Code Block
languagecpp
titleПлатежное поручение в распознаваемом Рутокен PINPad виде (UTF-8 кодировка)
char PINPADFILEUTF8[] = "<!PINPADFILE UTF8><N>ФИО:<V>Петров Петр Петрович Москва, Пионерская ул, д. 3, кв. 72"\
						"<N>Перевод со счета:<V>42301810001000075212<N>Сумма:<V>150000<N>Валюта:<V>RUR"\
						"<N>Наименование получателя:<V>Иванова Елена Ивановна<N>Номер счета получателя:<V>40817810338295201618"\
						"<N>БИК банка получателя:<V>044525225<N>Наименование банка получателя:<V>ОАО 'СБЕРБАНК РОССИИ' Г. МОСКВА"\
						"<N>Номер счета банка получателя:<V>30101810400000000225<N>Назначение платежа:<V>перевод личных средств";


Code Block
languagecpp
titleДанные в формате PINPADFILE для подписи без отображения в кодировке Windows-1251
char InvisibleCP1251[] = "<!PINPADFILE INVISIBLE RU>ФИО: Петров Петр Петрович Москва, Пионерская ул, д. 3, кв. 72"\
	                	"Перевод со счета: 42301810001000075212 Сумма: 150000 Валюта: RUR Наименование получателя: "\
	                	"Иванова Елена Ивановна Номер счета получателя: 40817810338295201618 БИК банка получателя: 044525225 "\
	                	"Наименование банка получателя: ОАО 'СБЕРБАНК РОССИИ' Г. МОСКВА Номер счета банка получателя: "\
	                	"30101810400000000225 Назначение платежа: перевод личных средств";


Code Block
languagecpp
titleДанные в формате PINPADFILE для подписи без отображения в кодировке UTF-8
char InvisibleUTF8[] = "<!PINPADFILE INVISIBLE UTF8><N>ФИО:<V>Петров Петр Петрович Москва, Пионерская ул, д. 3, кв. 72"\
						"<N>Перевод со счета:<V>42301810001000075212<N>Сумма:<V>150000<N>Валюта:<V>RUR"\
						"<N>Наименование получателя:<V>Иванова Елена Ивановна<N>Номер счета получателя:<V>40817810338295201618"\
						"<N>БИК банка получателя:<V>044525225<N>Наименование банка получателя:<V>ОАО 'СБЕРБАНК РОССИИ' Г. МОСКВА"\
						"<N>Номер счета банка получателя:<V>30101810400000000225<N>Назначение платежа:<V

Данные также могут быть представлены в виде двоичной строки с кодами символов в Windows-1251 или UTF-8.

Code Block
languagecpp
titleДанные в виде двоичной строки (PINPADFILE, Windows-1251)
char DataCP1251[] = { 0x3C, 0x21, 0x50, 0x49, 0x4E, 0x50, 0x41, 0x44, 0x46, 0x49, 0x4C, 0x45, 0x20, 0x52, 0x55, 0x3E,
					  0x3C, 0x4E, 0x3E, 0x0A, 0xD4, 0xC8, 0xCE, 0x3A, 0x3C, 0x56, 0x3E, 0xCF, 0xE5, 0xF2, 0xF0, 0xEE,
					  0xE2, 0x20, 0xCF, 0xE5, 0xF2, 0xF0, 0x20, 0xCF, 0xE5, 0xF2, 0xF0, 0xEE, 0xE2, 0xE8, 0xF7, 0x20,
					  0xCC, 0xEE, 0xF1, 0xEA, 0xE2, 0xE0, 0x2C, 0x20, 0xCF, 0xE8, 0xEE, 0xED, 0xE5, 0xF0, 0xF1, 0xEA,
					  0xE0, 0xFF, 0x20, 0xF3, 0xEB, 0x2C, 0x20, 0xE4, 0x2E, 0x20, 0x33, 0x2C, 0x20, 0xEA, 0xE2, 0x2E,
					  0x20, 0x37, 0x32, 0x2C, 0x20, 0xE2, 0xF2, 0xEE, 0xF0, 0xEE, 0xE9, 0x20, 0xF7, 0xE5, 0xF0, 0xE4,
					  0xE0, 0xEA, 0x0A, 0x3C, 0x4E, 0x3E, 0xCF, 0xE5, 0xF0, 0xE5, 0xE2, 0xEE, 0xE4, 0x20, 0xF1, 0xEE,
					  0x20, 0xF1, 0xF7, 0xE5, 0xF2, 0xE0, 0x3A, 0x3C, 0x56, 0x3E, 0x34, 0x32, 0x33, 0x30, 0x31, 0x38,
					  0x31, 0x30, 0x30, 0x30, 0x31, 0x30, 0x30, 0x30, 0x30, 0x37, 0x35, 0x32, 0x31, 0x32, 0x0A, 0x3C, 
					  0x4E, 0x3E, 0xD1, 0xF3, 0xEC, 0xEC, 0xE0, 0x3A, 0x3C, 0x56, 0x3E, 0x31, 0x35, 0x30, 0x30, 0x30,
					  0x30, 0x0A, 0x3C, 0x4E, 0x3E, 0xC2, 0xE0, 0xEB, 0xFE, 0xF2, 0xE0, 0x3A, 0x3C, 0x56, 0x3E, 0x52,
					  0x55, 0x52, 0x0A, 0x3C, 0x4E, 0x3E, 0xCD, 0xE0, 0xE8, 0xEC, 0xE5, 0xED, 0xEE, 0xE2, 0xE0, 0xED, 
					  0xE8, 0xE5, 0x20, 0xEF, 0xEE, 0xEB, 0xF3, 0xF7, 0xE0, 0xF2, 0xE5, 0xEB, 0xFF, 0x3A, 0x3C, 0x56,
					  0x3E, 0xC8, 0xE2, 0xE0, 0xED, 0xEE, 0xE2, 0xE0, 0x20, 0xC5, 0xEB, 0xE5, 0xED, 0xE0, 0x20, 0xC8, 
					  0xE2, 0xE0, 0xED, 0xEE, 0xE2, 0xED, 0xE0, 0x0A, 0x3C, 0x4E, 0x3E, 0xCD, 0xEE, 0xEC, 0xE5, 0xF0,
					  0x20, 0xF1, 0xF7, 0xE5, 0xF2, 0xE0, 0x20, 0xEF, 0xEE, 0xEB, 0xF3, 0xF7, 0xE0, 0xF2, 0xE5, 0xEB,
					  0xFF, 0x3A, 0x3C, 0x56, 0x3E, 0x34, 0x30, 0x38, 0x31, 0x37, 0x38, 0x31, 0x30, 0x33, 0x33, 0x38,
					  0x32, 0x39, 0x35, 0x32, 0x30, 0x31, 0x36, 0x31, 0x38, 0x0A, 0x3C, 0x4E, 0x3E, 0xC1, 0xC8, 0xCA,
					  0x20, 0xE1, 0xE0, 0xED, 0xEA, 0xE0, 0x20, 0xEF, 0xEE, 0xEB, 0xF3, 0xF7, 0xE0, 0xF2, 0xE5, 0xEB,
					  0xFF, 0x3A, 0x3C, 0x56, 0x3E, 0x30, 0x34, 0x34, 0x35, 0x32, 0x35, 0x32, 0x32, 0x35, 0x0A, 0x3C,
					  0x4E, 0x3E, 0xCD, 0xE0, 0xE8, 0xEC, 0xE5, 0xED, 0xEE, 0xE2, 0xE0, 0xED, 0xE8, 0xE5, 0x20, 0xE1,
					  0xE0, 0xED, 0xEA, 0xE0, 0x20, 0xEF, 0xEE, 0xEB, 0xF3, 0xF7, 0xE0, 0xF2, 0xE5, 0xEB, 0xFF, 0x3A,
					  0x3C, 0x56, 0x3E, 0xCE, 0xC0, 0xCE, 0x20, 0x27, 0xD1, 0xC1, 0xC5, 0xD0, 0xC1, 0xC0, 0xCD, 0xCA,
					  0x20, 0xD0, 0xCE, 0xD1, 0xD1, 0xC8, 0xC8, 0x27, 0x20, 0xC3, 0x2E, 0x20, 0xCC, 0xCE, 0xD1, 0xCA,
					  0xC2, 0xC0, 0x0A, 0x3C, 0x4E, 0x3E, 0xCD, 0xEE, 0xEC, 0xE5, 0xF0, 0x20, 0xF1, 0xF7, 0xE5, 0xF2,
					  0xE0, 0x20, 0xE1, 0xE0, 0xED, 0xEA, 0xE0, 0x20, 0xEF, 0xEE, 0xEB, 0xF3, 0xF7, 0xE0, 0xF2, 0xE5,
					  0xEB, 0xFF, 0x3A, 0x3C, 0x56, 0x3E, 0x33, 0x30, 0x31, 0x30, 0x31, 0x38, 0x31, 0x30, 0x34, 0x30,
					  0x30, 0x30, 0x30, 0x30, 0x30, 0x30, 0x30, 0x32, 0x32, 0x35, 0x0A, 0x3C, 0x4E, 0x3E, 0xCD, 0xE0,
					  0xE7, 0xED, 0xE0, 0xF7, 0xE5, 0xED, 0xE8, 0xE5, 0x20, 0xEF, 0xEB, 0xE0, 0xF2, 0xE5, 0xE6, 0xE0,
					  0x3A, 0x3C, 0x56, 0x3E, 0xEF, 0xE5, 0xF0, 0xE5, 0xE2, 0xEE, 0xE4, 0x20, 0xEB, 0xE8, 0xF7, 0xED,
					  0xFB, 0xF5, 0x20, 0xF1, 0xF0, 0xE5, 0xE4, 0xF1, 0xF2, 0xE2 };

 

Code Block
languagecpp
titleДанные в виде двоичной строки (PINPADFILE, UTF-8)
char DataUTF8[] = { 0x3C, 0x21, 0x50, 0x49, 0x4E, 0x50, 0x41, 0x44, 0x46, 0x49, 0x4C, 0x45, 0x20, 0x55, 0x54, 0x46, 
					0x38, 0x3E, 0x3C, 0x4E, 0x3E, 0xD0, 0xA4, 0xD0, 0x98, 0xD0, 0x9E, 0x3A, 0x3C, 0x56, 0x3E, 0xD0, 
					0x9F, 0xD0, 0xB5, 0xD1, 0x82, 0xD1, 0x80, 0xD0, 0xBE, 0xD0, 0xB2, 0x20, 0xD0, 0x9F, 0xD0, 0xB5, 
					0xD1, 0x82, 0xD1, 0x80, 0x20, 0xD0, 0x9F, 0xD0, 0xB5, 0xD1, 0x82, 0xD1, 0x80, 0xD0, 0xBE, 0xD0, 
					0xB2, 0xD0, 0xB8, 0xD1, 0x87, 0x20, 0xD0, 0x9C, 0xD0, 0xBE, 0xD1, 0x81, 0xD0, 0xBA, 0xD0, 0xB2, 
					0xD0, 0xB0, 0x2C, 0x20, 0xD0, 0x9F, 0xD0, 0xB8, 0xD0, 0xBE, 0xD0, 0xBD, 0xD0, 0xB5, 0xD1, 0x80, 
					0xD1, 0x81, 0xD0, 0xBA, 0xD0, 0xB0, 0xD1, 0x8F, 0x20, 0xD1, 0x83, 0xD0, 0xBB, 0x2C, 0x20, 0xD0, 
					0xB4, 0x2E, 0x20, 0x33, 0x2C, 0x20, 0xD0, 0xBA, 0xD0, 0xB2, 0x2E, 0x20, 0x37, 0x32, 0x3C, 0x4E, 
					0x3E, 0xD0, 0x9F, 0xD0, 0xB5, 0xD1, 0x80, 0xD0, 0xB5, 0xD0, 0xB2, 0xD0, 0xBE, 0xD0, 0xB4, 0x20, 
					0xD1, 0x81, 0xD0, 0xBE, 0x20, 0xD1, 0x81, 0xD1, 0x87, 0xD0, 0xB5, 0xD1, 0x82, 0xD0, 0xB0, 0x3A, 
					0x3C, 0x56, 0x3E, 0x34, 0x32, 0x33, 0x30, 0x31, 0x38, 0x31, 0x30, 0x30, 0x30, 0x31, 0x30, 0x30, 
					0x30, 0x30, 0x37, 0x35, 0x32, 0x31, 0x32, 0x3C, 0x4E, 0x3E, 0xD0, 0xA1, 0xD1, 0x83, 0xD0, 0xBC, 
					0xD0, 0xBC, 0xD0, 0xB0, 0x3A, 0x3C, 0x56, 0x3E, 0x31, 0x35, 0x30, 0x30, 0x30, 0x30, 0x3C, 0x4E, 
					0x3E, 0xD0, 0x92, 0xD0, 0xB0, 0xD0, 0xBB, 0xD1, 0x8E, 0xD1, 0x82, 0xD0, 0xB0, 0x3A, 0x3C, 0x56, 
					0x3E, 0x52, 0x55, 0x52, 0x3C, 0x4E, 0x3E, 0xD0, 0x9D, 0xD0, 0xB0, 0xD0, 0xB8, 0xD0, 0xBC, 0xD0, 
					0xB5, 0xD0, 0xBD, 0xD0, 0xBE, 0xD0, 0xB2, 0xD0, 0xB0, 0xD0, 0xBD, 0xD0, 0xB8, 0xD0, 0xB5, 0x20, 
					0xD0, 0xBF, 0xD0, 0xBE, 0xD0, 0xBB, 0xD1, 0x83, 0xD1, 0x87, 0xD0, 0xB0, 0xD1, 0x82, 0xD0, 0xB5, 
					0xD0, 0xBB, 0xD1, 0x8F, 0x3A, 0x3C, 0x56, 0x3E, 0xD0, 0x98, 0xD0, 0xB2, 0xD0, 0xB0, 0xD0, 0xBD, 
					0xD0, 0xBE, 0xD0, 0xB2, 0xD0, 0xB0, 0x20, 0xD0, 0x95, 0xD0, 0xBB, 0xD0, 0xB5, 0xD0, 0xBD, 0xD0, 
					0xB0, 0x20, 0xD0, 0x98, 0xD0, 0xB2, 0xD0, 0xB0, 0xD0, 0xBD, 0xD0, 0xBE, 0xD0, 0xB2, 0xD0, 0xBD, 
					0xD0, 0xB0, 0x3C, 0x4E, 0x3E, 0xD0, 0x9D, 0xD0, 0xBE, 0xD0, 0xBC, 0xD0, 0xB5, 0xD1, 0x80, 0x20, 
					0xD1, 0x81, 0xD1, 0x87, 0xD0, 0xB5, 0xD1, 0x82, 0xD0, 0xB0, 0x20, 0xD0, 0xBF, 0xD0, 0xBE, 0xD0, 
					0xBB, 0xD1, 0x83, 0xD1, 0x87, 0xD0, 0xB0, 0xD1, 0x82, 0xD0, 0xB5, 0xD0, 0xBB, 0xD1, 0x8F, 0x3A, 
					0x3C, 0x56, 0x3E, 0x34, 0x30, 0x38, 0x31, 0x37, 0x38, 0x31, 0x30, 0x33, 0x33, 0x38, 0x32, 0x39, 
					0x35, 0x32, 0x30, 0x31, 0x36, 0x31, 0x38, 0x3C, 0x4E, 0x3E, 0xD0, 0x91, 0xD0, 0x98, 0xD0, 0x9A, 
					0x20, 0xD0, 0xB1, 0xD0, 0xB0, 0xD0, 0xBD, 0xD0, 0xBA, 0xD0, 0xB0, 0x20, 0xD0, 0xBF, 0xD0, 0xBE, 
					0xD0, 0xBB, 0xD1, 0x83, 0xD1, 0x87, 0xD0, 0xB0, 0xD1, 0x82, 0xD0, 0xB5, 0xD0, 0xBB, 0xD1, 0x8F, 
					0x3A, 0x3C, 0x56, 0x3E, 0x30, 0x34, 0x34, 0x35, 0x32, 0x35, 0x32, 0x32, 0x35, 0x3C, 0x4E, 0x3E, 
					0xD0, 0x9D, 0xD0, 0xB0, 0xD0, 0xB8, 0xD0, 0xBC, 0xD0, 0xB5, 0xD0, 0xBD, 0xD0, 0xBE, 0xD0, 0xB2, 
					0xD0, 0xB0, 0xD0, 0xBD, 0xD0, 0xB8, 0xD0, 0xB5, 0x20, 0xD0, 0xB1, 0xD0, 0xB0, 0xD0, 0xBD, 0xD0, 
					0xBA, 0xD0, 0xB0, 0x20, 0xD0, 0xBF, 0xD0, 0xBE, 0xD0, 0xBB, 0xD1, 0x83, 0xD1, 0x87, 0xD0, 0xB0, 
					0xD1, 0x82, 0xD0, 0xB5, 0xD0, 0xBB, 0xD1, 0x8F, 0x3A, 0x3C, 0x56, 0x3E, 0xD0, 0x9E, 0xD0, 0x90, 
					0xD0, 0x9E, 0x20, 0x27, 0xD0, 0xA1, 0xD0, 0x91, 0xD0, 0x95, 0xD0, 0xA0, 0xD0, 0x91, 0xD0, 0x90, 
					0xD0, 0x9D, 0xD0, 0x9A, 0x20, 0xD0, 0xA0, 0xD0, 0x9E, 0xD0, 0xA1, 0xD0, 0xA1, 0xD0, 0x98, 0xD0, 
					0x98, 0x27, 0x20, 0xD0, 0x93, 0x2E, 0x20, 0xD0, 0x9C, 0xD0, 0x9E, 0xD0, 0xA1, 0xD0, 0x9A, 0xD0, 
					0x92, 0xD0, 0x90, 0x3C, 0x4E, 0x3E, 0xD0, 0x9D, 0xD0, 0xBE, 0xD0, 0xBC, 0xD0, 0xB5, 0xD1, 0x80, 
					0x20, 0xD1, 0x81, 0xD1, 0x87, 0xD0, 0xB5, 0xD1, 0x82, 0xD0, 0xB0, 0x20, 0xD0, 0xB1, 0xD0, 0xB0, 
					0xD0, 0xBD, 0xD0, 0xBA, 0xD0, 0xB0, 0x20, 0xD0, 0xBF, 0xD0, 0xBE, 0xD0, 0xBB, 0xD1, 0x83, 0xD1, 
					0x87, 0xD0, 0xB0, 0xD1, 0x82, 0xD0, 0xB5, 0xD0, 0xBB, 0xD1, 0x8F, 0x3A, 0x3C, 0x56, 0x3E, 0x33, 
					0x30, 0x31, 0x30, 0x31, 0x38, 0x31, 0x30, 0x34, 0x30, 0x30, 0x30, 0x30, 0x30, 0x30, 0x30, 0x30, 
					0x32, 0x32, 0x35, 0x3C, 0x4E, 0x3E, 0xD0, 0x9D, 0xD0, 0xB0, 0xD0, 0xB7, 0xD0, 0xBD, 0xD0, 0xB0, 
					0xD1, 0x87, 0xD0, 0xB5, 0xD0, 0xBD, 0xD0, 0xB8, 0xD0, 0xB5, 0x20, 0xD0, 0xBF, 0xD0, 0xBB, 0xD0, 
					0xB0, 0xD1, 0x82, 0xD0, 0xB5, 0xD0, 0xB6, 0xD0, 0xB0, 0x3A, 0x3C, 0x56, 0x3E, 0xD0, 0xBF, 0xD0, 
					0xB5, 0xD1, 0x80, 0xD0, 0xB5, 0xD0, 0xB2, 0xD0, 0xBE, 0xD0, 0xB4, 0x20, 0xD0, 0xBB, 0xD0, 0xB8, 
					0xD1, 0x87, 0xD0, 0xBD, 0xD1, 0x8B, 0xD1, 0x85, 0x20, 0xD1, 0x81, 0xD1, 0x80, 0xD0, 0xB5, 0xD0, 
					0xB4, 0xD1, 0x81, 0xD1, 0x82, 0xD0, 0xB2 };

 

Формат XML-тегов (загружаемая таблица разметки)

...

 

Code Block
languagecpp
titleДанные в формате XML для подписи c отображением в кодировке Windows-1251
char XMLDataCP1251[] =	"<?xml version=\"1.0\" encoding=\"windows-1251\"?><Файл><ИмяФайла>Name-00001.XML</ИмяФайла><ЗаголовокФайла>"\
	                	"<ВерсияФормата>01.00</ВерсияФормата><ТипФайла>ВНЕШНИЙ</ТипФайла></ЗаголовокФайла><ФИО><Фамилия>Петров</Фамилия>"\
						"<Имя>Сергей</Имя><Отчество>Александрович</Отчество></ФИО><Пол>М</Пол><ДатаРождения>01.02.1990</ДатаРождения>"\
						"<ДатаЗаполнения>01.02.2015</ДатаЗаполнения><ext><МестоРожд>г. Москва</МестоРожд><Адрес><Индекс>123456</Индекс>"\
						"<Область>Московская обл.</Область><Район>Первомайский р-н</Район>Город>г. Москва</Город><Улица>ул. Первомайская </Улица>"\
						"<Дом>3</Дом><Корпус>1</Корпус><Квартира>123</Квартира></Адрес></ext></Файл>";

 

 

Code Block
languagecpp
titleДанные в формате XML для подписи c отображением в кодировке UTF-8
char XMLDataUTF8[] =	"<?xml version=\"1.0\" encoding=\"utf-8\"?><Файл><ИмяФайла>Name-00001.XML</ИмяФайла><ЗаголовокФайла>"\
	                	"<ВерсияФормата>01.00</ВерсияФормата><ТипФайла>ВНЕШНИЙ</ТипФайла></ЗаголовокФайла><ФИО><Фамилия>Петров</Фамилия>"\
						"<Имя>Сергей</Имя><Отчество>Александрович</Отчество></ФИО><Пол>М</Пол><ДатаРождения>01.02.1990</ДатаРождения>"\
						"<ДатаЗаполнения>01.02.2015</ДатаЗаполнения><ext><МестоРожд>г. Москва</МестоРожд><Адрес><Индекс>123456</Индекс>"\
						"<Область>Московская обл.</Область><Район>Первомайский р-н</Район>Город>г. Москва</Город><Улица>ул. Первомайская </Улица>"\
						"<Дом>3</Дом><Корпус>1</Корпус><Квартира>123</Квартира></Адрес></ext></Файл>";

 

Формат хранения загружаемой таблицы тегов

...

Сырые данные

Если данные не содержат в начале документа ни одного из заголовков <!PINPADFILE RU><!PINPADFILE UTF8><!PINPADFILE INVISIBLE RU> или <!PINPADFILE INVISIBLE UTF8>, ни тегов из загружаемой таблицы разметки данных или загружаемая таблица отсутствует, Рутокен PINPad отображает все содержимое документа в виде "как есть", предлагая затем подписать документ или отказаться от подписи. 

 

Code Block
languagecpp
titleДанные для подписи без форматирования
char RawData[] = "ФИО: Петров Петр Петрович Москва, Пионерская ул, д. 3, кв. 72 Перевод со счета: 42301810001000075212 "\
				 "Сумма: 150000 Валюта: RUR Наименование получателя: Иванова Елена Ивановна Номер счета получателя: "\
				 "40817810338295201618 БИК банка получателя: 044525225 Наименование банка получателя: ОАО 'СБЕРБАНК РОССИИ' Г. МОСКВА "\
				 "Номер счета банка получателя: 30101810400000000225 Назначение платежа: перевод личных средств";

 

Подпись данных 

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

...

Особенности подписи данных на Рутокен PINPad 

...

Подпись данных отдельными механизмами хеширования и подписи

...

При использовании отдельных механизмов хеширования и подписи сообщение сначала хешируется функциями C_DigestInit() и C_Digest(), а затем значение хеша подписывается функциями C_SignInit()/C_EX_SignInvisibleInit() и C_Sign()/C_EX_SignInvisible().

В функцию C_DigestInit() передается механизм хеширования (например, CKM_GOSTR3411), а в функцию C_Digest() – само сообщение. При вызове функция C_Digest() вычисляет хеш сообщения и возвращает управление вместе со значением хеша. Исходное сообщение и значение хеша запоминаются в памяти Рутокен PINPad.

Затем вызывается функция инициализации подписи C_SignInit()/C_EX_SignInvisibleInit(), в которую передается механизм подписи (например, CKM_GOSTR3410), и сама функция подписи C_Sign()/C_EX_SignInvisible() с переданным в нее значением хеша.

Если подпись выполняется ключевой парой с атрибутом CKA_VENDOR_KEY_CONFIRM_OP равным true, то при вызове функции C_EX_SignInvisible() подпись выполняется в автоматическом режиме. Рутокен PINPad сверяет сохраненное значение хеша с переданным функцией C_EX_SignInvisible() и в случае совпадения выполняет подпись хеша и возвращает блок сформированной подписи размером 64 байта для механизма CKM_GOSTR3410 и 128 байт для механизма CKM_GOSTR3410_512.  Если значения хешей не совпадают, функция C_EX_SignInvisible() возвращает ошибку.

Если подпись выполняется ключевой парой с атрибутом CKA_VENDOR_KEY_CONFIRM_OP равным true, то при вызове функции C_Sign() Рутокен PINPad сверяет сохраненное значение хеша с переданным функцией и в случае совпадения отображает на экране текст исходного сообщения. Функция C_Sign() ожидает нажатия пользователем кнопки подтверждения или отказа от операции на экране Рутокен PINPad. Если значения хешей не совпадают, функция C_Sign() возвращает ошибку без вывода на экране текста сообщения.

Если пользователь подтверждает выполнение операции, то сохраненное значение хеша в Рутокен PINPad подписывается, и функция C_Sign() возвращает управление и блок сформированной цифровой подписи размером 64 байта для механизма CKM_GOSTR3410 и 128 байт для механизма CKM_GOSTR3410_512

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

...

Пример подписи данных по алгоритму ГОСТ Р 34.10-2001 отдельными механизмами хеширования и подписи для всех устройств Рутокен

...

Пример подписи данных по алгоритму ГОСТ Р 34.10-2012 отдельными механизмами хеширования и подписи для всех устройств Рутокен

...

При использовании совместного механизма и хеширование, и подпись выполняются функцией C_Sign(). Сначала в функцию C_SignInit() передается совместный механизм (например, CKM_GOSTR3410_WITH_GOSTR3411), а затем в функцию C_Sign() – сообщение.

Пример подписи данных по алгоритму ГОСТ Р 34.10-2001 совместным механизмом хеширования и подписи (кроме Рутокен PINPad)

...

Пример подписи данных по алгоритму ГОСТ Р 34.10-2012 совместным механизмом хеширования и подписи (кроме Рутокен PINPad)

...

При использовании совместного механизма и хеширование, и подпись выполняются функцией C_EX_SignInvisible(). Сначала в функцию C_EX_SignInvisibleInit() передается совместный механизм (например, CKM_GOSTR3410_WITH_GOSTR3411), а затем в функцию C_EX_SignInvisible() – сообщение.

При вызове функции C_EX_SignInvisible() подпись будет выполнена в автоматическом режиме без отображения подписываемого сообщения на экране Рутокен PINPad.

Пример подписи данных по алгоритму ГОСТ Р 34.10-2001 совместным механизмом хеширования и подписи для Рутокен PINPad

...

Пример подписи данных по алгоритму ГОСТ Р 34.10-2012 совместным механизмом хеширования и подписи для Рутокен PINPad

...