node pcsclite读卡证书

时间:2016-02-24 21:28:12

标签: node.js smartcard pcsc

我已经得到了我认为是一个相当简单的应用程序,其中我使用的是debian Linux(不必跨平台),我需要阅读智能卡获取用户的UID / LDAP用户名,该用户名应存储在卡上的证书中。

我使用PowerShell在Windows上成功完成了这类事情,如下所示:View All Certificates On Smart Card

但是我在节点上努力做同样的事情。到目前为止我已经在pcsclite中使用了node-pcsclite示例代码来验证环境是否有效。这是我成功运行的代码:

#!/usr/bin/env node

var pcsc = require('../index');

var pcsc = pcsc();
pcsc.on('reader', function(reader) {

    console.log('New reader detected', reader.name);

    reader.on('error', function(err) {
        console.log('Error(', this.name, '):', err.message);
    });

    reader.on('status', function(status) {
        console.log('Status(', this.name, '):', status);
        /* check what has changed */
        var changes = this.state ^ status.state;
        if (changes) {
            if ((changes & this.SCARD_STATE_EMPTY) && (status.state & this.SCARD_STATE_EMPTY)) {
                console.log("card removed");/* card removed */
                reader.disconnect(reader.SCARD_LEAVE_CARD, function(err) {
                    if (err) {
                        console.log(err);
                    } else {
                        console.log('Disconnected');
                    }
                });
            } else if ((changes & this.SCARD_STATE_PRESENT) && (status.state & this.SCARD_STATE_PRESENT)) {
                console.log("card inserted");/* card inserted */
                reader.connect({ share_mode : this.SCARD_SHARE_SHARED }, function(err, protocol) {
                    if (err) {
                        console.log(err);
                    } else {
                        console.log('Protocol(', reader.name, '):', protocol);
                        reader.transmit(new Buffer([0x00, 0xB0, 0x00, 0x00, 0x20]), 40, protocol, function(err, data) {
                            if (err) {
                                console.log(err);
                            } else {
                                console.log('Data received', data);
                                reader.close();
                                pcsc.close();
                            }
                        });
                    }
                });
            }
        }
    });

    reader.on('end', function() {
        console.log('Reader',  this.name, 'removed');
    });
});

pcsc.on('error', function(err) {
    console.log('PCSC error', err.message);
});

因此,这完全符合记录,没有问题。如果我插入智能卡,我会得到预期的输出。

我不喜欢什么是'数据'在.transmit()回调代表。它是一个缓冲区,一个十六进制数字的数组(看起来像),但我不明白我是如何将其变成可读的东西,我可以比较访问批准(为此app,我只是想将用户的UID与白名单进行比较。

我已经尝试过阅读pcsc-lite文档和PC / SC标准,但到目前为止,数据的实际含义对我来说是非常不透明的。

当然,我尝试了一些简单的事情,例如用各种编码调用data.toString(),到目前为止没有成功。

有关如何从node-pcsclite获取我目前所获得的内容并收集任何类型的人类可读信息的任何想法?

0 个答案:

没有答案