当前位置: 首页 > 面试题库 >

在Android中将APDU命令发送到USIM / SIM卡

公孙成仁
2023-03-14
问题内容

我已经使用过智能卡,并且熟悉APDU命令(在 ISO / IEC 7816Global Platform 规范中定义)。

现在,我想知道是否有什么方法可以将APDU命令发送到插入手机的USIM / SIM卡?(安装了Android v4.4.4 kitkat的三星A3。)

我已经在Google中搜索过,发现了一些相关的主题和工具,名为 SIM Toolkit Application and Seek for
Android
。但是我真的不明白这些是什么?这些项目是我必须在手机上安装的两个应用程序吗?还是已经在USIM /
SIM卡上安装了这两个工具并从手机接收命令?

主动命令APDU命令AT命令 之间有什么区别?

我应该学习Android开发SIM卡应用程序还是只需要Java Card规范和ETSI标准?

提前致谢。


问题答案:

SIM卡上可能存在两种不同类型的小程序。

普通小程序

用简单的JavaCard编写的常见applet。这是您习惯于普通智能卡世界中的applet的类型。它具有process方法,智能卡是通信中的被动主题:您的应用发送APDU命令和卡响应。

您可以使用一组称为SEEK for
Android的特殊Android库与这些applet通信。看一下本教程,学习如何创建这样的电话应用程序。

从API级别21开始,还有一种使用Telephony
Manager与SIM进行通信的方法。但是,有一个巨大的障碍:您的应用需要MODIFY_PHONE_STATE权限,该权限只能授予系统应用。不允许使用非常规应用程序。

SIM工具包小程序

SIM卡不仅仅是普通的智能卡,而且如果您想使用SIM卡提供的所有功能,那么为SIM卡编写小程序可能比普通的智能卡复杂得多。我建议您阅读本文
-这是某人的学士论文,但这是我在Internet上找到的初学者的最佳概述。我也推荐DefConn会议上的这段视频。

加载到SIM卡上的applet的角色是不同的:applet不再是被动实体。电话会定期问您的小程序:“有什么可以为您做的新事情吗?”
并且您的applet可以回答:“是,请发送此SMS”或“告诉我现在几点了”等等。此外,您的applet可以成为某些事件的侦听器:来电,收到的SMS,经过的时间间隔等。
,从技术角度看,SIM卡似乎是被动的,但实际上它的作用是主动的:SIM卡向电话发送命令。

这些命令称为“主动命令”或SIM Application Toolkit命令。结构相同-CLA INS P1 P2 LC数据LE; 意思是不同的。

您可以使用名为的特殊JavaCard包中的类从小程序中发送它们sim.toolkit

(SIM Application Toolkit是一个标准,它以与Global Platform指定applet生命周期相同的方式指定主动命令。)

SIM Toolkit小程序示例:

import sim.toolkit.ToolkitInterface;
import sim.toolkit.ToolkitRegistry;
...
import javacard.framework.ISOException;

public class STKTest extends Applet implements ToolkitInterface {

public static void install(byte[] bArray, short bOffset, byte bLength) {
    // GP-compliant JavaCard applet registration
    new STKTest().register(bArray, (short) (bOffset + 1), bArray[bOffset]);
}
//this method handles standard APDU commands
public void process(APDU apdu) {
    // Good practice: Return 9000 on SELECT
    if (selectingApplet()) {
        return;
    }

    apdu.setIncomingAndReceive();
    final byte[] buf = apdu.getBuffer();
    switch (buf[ISO7816.OFFSET_INS]) {
    case (byte) 0x00:
        //do something
        break;
    }
}
//this method handles the SIM Toolkit commands
public void processToolkit(byte event) throws ToolkitException {
    switch (event) {

    case ToolkitConstants.EVENT_TIMER_EXPIRATION:
        //do something
        break;
    }
}

}

是的,您应该学习Android-使用SEEK库将需要它。您的问题非常广泛,如果需要,请询问我任何详细信息。



 类似资料:
  • 我试图通过APDUs命令通过HID OMNIKEY 5427 CK操作MIFARE卡ie。超轻C卡,在Windows 10 x64操作系统环境下使用WinSCard.dll。(我隶属恩智浦NDA公司,可以完全访问他们的文件) 我试着在网上找了好几天的信息。除了2页的小册子,似乎没有针对这个模型发布的文档。 像GetUID(FFCA000000)这样的简单命令就可以了,我可以取回实际的卡UID。 但

  • 问题内容: 我在Windows XP上使用Java,并且希望能够将命令发送到另一个程序,例如telnet。我不想简单地执行另一个程序。我要执行它,然后在它运行后向它发送一系列命令。这是我要执行的操作的代码,但是无效:(如果取消注释,并将命令更改为“ cmd”,它将按预期工作。请帮助。)这是一个简化的示例。在生产中,将发送更多命令,因此 请不要建议调用“ telnet localhost”。 问题答

  • 问题内容: 我当前的部分看起来像这样: …这意味着我可以运行来启动服务器。到现在为止还挺好。 但是,我希望能够运行类似的东西并将参数传递给(例如=> )。这可能吗? 问题答案: 编辑: 可以将args传递给npm2.0.0 语法如下: 注意必要的。需要将传递给命令本身的参数和传递给脚本的参数分开。 所以如果你有 那么以下命令将是等效的: => => 为了读取命名参数,最好使用yargs或[mini

  • 我使用的是Sony FeliCa RC-S380,我想在读卡器处于读写器模式时,以卡模拟模式(HCE)向Android设备发送一些APDU命令。从外观上看,我可以使用Windows接近库来处理与该读卡器的通信,但我似乎无法找到将读卡器置于读写器模式以发送APDU命令和接收响应的方法。 ProximityDevice类用于发送名为PublishBinaryMessage的消息的函数,它看起来最像我想

  • 我有curl请求从Android推送数据到服务器。下面是Curl请求: 我应该如何使用截击进行post请求?我很困惑,因为我不知道该放在哪里: 所以请任何人帮我完成这件事。任何答案都是可贵的。非常感谢。安静!

  • 我正在连接android设备的PC上运行自动测试工具;我发现在测试期间,工具向设备发送了一些adb命令;我想知道亚行的命令到底是什么?如何捕捉PC或android设备上的命令? 我想得到这样的结果:“adb安装xxx.apk”