Skip to content

Latest commit

 

History

History
34 lines (30 loc) · 2.92 KB

README.md

File metadata and controls

34 lines (30 loc) · 2.92 KB

Websocket-Smart-Card-Signer

Websocket based (NO APPLET) Smart Card Digital Signature Application

Websocket-Smart-Card-Signer give the possibility to sign a document with a Smartcard, directly from the browser. The application work as a Websocket server and is provided with a javascript client library that manage the communications. The application support the signature of online and local PDF documents in PAdES standard as well as the signature of any other kind of file in P7M using the CAdES standard. This application depend on the projects Java Native Interface for PKCS#11 and IAIK PKCS#11 Wrapper. More details on the features in the following.

Features

  • Websocket based. Did not use the deprecated APPLET technology
  • PKCS#11 Access directly through JNA or using IAIK
  • Multi-OS and Multi-Smartcard Support
    • The following PKCS11 libraries are automatically identified in the system: "incryptoki2.dll", "bit4ipki.dll", "bit4opki.dll", "bit4xpki.dll", "OCSCryptoki.dll", "asepkcs.dll", "SI_PKCS11.dll", "cmP11.dll", "cmP11_M4.dll", "IpmPki32.dll", "IPMpkiLC.dll", "IpmPkiLU.dll", "bit4cpki.dll", "bit4p11.dll", "asepkcs.dll", "PKCS11.dll", "eTPKCS11.dll", "SSC_PKCS11.dll", "inp11lib.dll", "opensc-pkcs11.dll", "libbit4opki.so", "libbit4spki.so", "libbit4p11.so", "libbit4ipki.so", "opensc-pkcs11.so", "libeTPkcs11.so", "libopensc.dylib", "libbit4xpki.dylib", "libbit4ipki.dylib", "libbit4opki.dylib", "libASEP11.dylib", "libeTPkcs11.dylib"
    • Possibility to define custom PKCS11 libraries in case your Smartcard's PKCS11 is not listed above
  • Access to all the Smartcard available certificates
  • Recognition of multiple connected Smartcard
  • Multi-Document signature
  • P7M Signature in CAdES Standard format
  • PDF Signature in PAdES Standard format
  • Possibility configure the signature visibility and position in the PDF
  • Avoid previous signature nesting
  • Possibility to allow the signature only for specific user IDs
  • Possibility to use a NTP service to automatically set the signature timestamp
  • Validation of the generated signature
  • Automatic diagnosis of Smartcard problems
  • Possibility to be used as standalone document signature application using the try icon menu functions

Live DEMO

Have a look at the DEMO.

NOTE: The Jar is self-signed so in order to use the demo in JNLP mode you must add a security exception in the java control panel for the site "https://damianofalcioni.github.io/"

Support Me <3

Buy me a coffee