0

我一直在尝试在 Java 上进行相互身份验证,这就是我正在做的事情:

首先,我要求挑战并获得随机数。

TRX --> 0084000008
REC <-- 4E621D238C8B185F 9000 

然后我计算所有内容,密钥种子、enc、mac 并发送相互授权命令:

TRX --> 0082000028[seed enc mac ... bytes transformed]00
REC <-- 6A88

我总是收到 0x6A88,我在互联网上发现它的意思是“未找到参考数据或参考数据”。

但奇怪的是,我的 prois 实现了已经在 C# 到 Java 上运行的代码,我们已经对其进行了测试,我们使用密钥等获得了相同的数据,我发现当我要发送相互身份验证时( 0x82) 命令我得到了 0x6A88 错误。

这是一些源代码,我想表明我已经尝试过使用和不使用 beginExclusive() 和 endExclusive(),但没有奏效。

public CardTerminal getCardTerminal() throws Exception {
    CardTerminal ct = null;
    TerminalFactory terminalFactory = TerminalFactory.getDefault();        
    CardTerminals cardTerminals = terminalFactory.terminals();
    // Searches for first card terminal available on the PC
    if (cardTerminals.list().isEmpty() == false) {
        ct = cardTerminals.list().get(0);
    }
    return ct;
}

public void test() throws Exception {
    CardTerminal cardTerminal;
    Card card;
    MyManager instance;

    cardTerminal = getCardTerminal(); 
    instance = new DpiV2Manager();

    card = cardTerminal.connect("T=1");
    card = connect(cardTerminal);
    card.beginExclusive();
    CardChannel cardChannel = card.getBasicChannel();

    // Inside this method I do the get challange, mutual auth, etc
    instance.readGeneralData(cardChannel); 

    card.endExclusive();
    card.disconnect(true);
}

有人对 Java 进行相互身份验证有同样的问题吗?

有人找到解决方案了吗?

4

1 回答 1

0

我的问题是我试图在错误的小程序上进行相互身份验证。我只是在get challenge APDU前选择了正确的applet id,终于搞定了。

于 2014-09-12T19:10:10.990 回答