This is a very simple maven project which reads the code (uid) of your RFID chip, and types it as if it were typed on a keyboard.
Although one might think this should be simple, due to the availability of the javax.smartcardio
, nothing could be further from the truth.
There are a number of issues with this part of the javax
library:
- On some platform, methods as
waitForCardAbsent
andwaitForCardPresent
may block indefinitely, albeit setting a timeout value. - On some platform, methods as
waitForCardAbsent
andwaitForCardPresent
may continue even if the condition is simply not met. - Scanners can become disconnected from your software, causing random failures after a period of time.
- The exceptions thrown by the JVM may differ per platform. On OSX a
CardException
may be raised, whereas Windows can trigger aCardNotPresentException
under the same circumstances. - When sending a command to a card and waiting for a response, if the card is removed before sending a response your thread becomes blocked indefinitely.
In general, this makes development quite hard and testing close to impossible. Timeouts may be triggered after several hours of correct functioning, or simply after a minute of idle time.
This small program attempts to mediate these issues, such that scanning of cards is viable cross platform within the JVM.
The software uses the Jna SmartcardIO libary wrapper.
This library is more resilient than the default javax.smartcardio
library.
Apart from that, the service extensively uses bulkheads to isolate from possible failures. Each card scanning action is performed with a Future in a separate ExecutorService. This way, we can cancel actions if the card did not respond in time (usually due to card removal).
To prevent scanner disconnects, the software will keep track of the last scan action time, and reconnect if that was too long ago.
To run, use mvn clean install package
which will create two jar files which are executable.
One of these is lean, the other includes all dependencies.
The latter one should be used by clients.
Alternatively, you can run mvn clean install exec:java
to execute things directly from the CLI.
Generally, just don't. These cables may have all kind of issues. Especially USB RFID readers are really vulnerable for this, since they need sufficient power to create a field where the RFID tag can operate in. In you want to use an extension cable, use a powered USB hub. These ensure that the voltage is high enough for the reader to function.
Any successful merge to master
is automatically available on the Github release page.
Always send the most recent version to our customers.