Page tree

Versions Compared

Key

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

...

Особенности сборки для Android

Добавьте в ваш проект pkcs#11 PKCS#11 библиотеку. Для этого просто подключите к вашему проекту nuget NuGet пакет Aktiv.RtPkcs11Ecp.Natives.Android

Для работы с PKCS#11 вам также необходимо добавить в проект две библиотеки: rtserviceconnection.aar и pkcs11jna.jar. Их можно взять из нашего sdk SDK в директориях sdk\mobile\android\libs и sdk\java\samples\lib. Для того, чтобы добавить их в свой проект опишите опишите их в файле проекта:

...

Помимо jar и aar библиотек вам нужно добавить в свой проект саму pkcs#11 библиотеку. 

Особенности сборки для

...

iOS

Минимальная настройка

Добавьте в ваш проект pkcs#11 PKCS#11 библиотеку. Для этого просто подключите к вашему проекту nuget пакет Aktiv.RtPkcs11Ecp.Natives.iOS. А также добавьте в Info.plist файл строчку:

...

Этого будет достаточно для работы с Рутокен ЭЦП Bluetooth токенами.

Добавление поддержки NFC карт

Для того, чтобы ваше приложение умело работать также и с Рутокен ЭЦП 3.0 NFC токенами:

  1.  Добавьте в Info.plist строчки:

    Code Block
    languagebash
    titleInfo.plist
    <key>NFCReaderUsageDescription</key>
    <string>Allow NFC scanning</string>
    <key>com.apple.developer.nfc.readersession.iso7816.select-identifiers</key>
    <array>
        <string>F00000000010000000000100</string>
        <string>A000000151000000</string>
        <string>A00000039742544659</string>
    </array>


  2. В файл Entitlements.plist добавьте строчки:

    Code Block
    languagebash
    titleEntitlements.plist
    <key>com.apple.developer.nfc.readersession.formats</key>
    <array>
        <string>NDEF</string>
        <string>TAG</string>
    </array>


  3. Перед началом взаимодействия с с Рутокен ЭЦП 3.0 NFC токеном запустите функцию startNFC из фреймворка RtPcsc. Эта функция в отдельном потоке окно с просьбой приложить NFC карту к телефону или планшету. На вход она принимает колбекcallback, который будет вызван в случае ошибок, например если окно закрылось по таймауту или пользователь нажал на клавишу "Отмена".

    Напрямую вызвать эти функции не получится т.к. они имеют objObj-c C сигнатуру и в качестве колбека callback принимает литеральный блок. Но это ограничение можно обойти воспользовавшись Xamarin оберткой над блоками, например, как это сделано здесь. Подробнее о том, как писать такие обертки написано здесь.
  4. После окончания взаимодействия с NFC токеном запустите функцию stopNFC из фреймворка RtPcsc. 
  5. Поток с окном предложения приложить токен и поток работы с pkcs#11 PKCS#11 функциями надо синхронизировать: токен не сразу распознается системой и нужно некоторое время подождать прежде чем начать работать с ним. У нас в коде это сделано с помощью функции C_WaitForSlotEvent и атомарный флаг остановки работы с nfc.

...