adb install-multiple 1.apk 2.apk
python nicegui
apt install python3-venv python3-pip python3 -m venv /home/user/python source python/bin/activate python3 -m pip install nicegui
Smart card ATR parsing
在线分析
源代码: https://github.com/LudovicRousseau/pyscard-contrib/tree/master/parseATR
从ATR中就可以看出是否支持eUICC功能
TB(3) = 0x82 –> eUICC-related functions supported
3B 9F 96 80 3F C7 82 80 31 E0 73 FE 21 1B 63 3A 20 4E 83 00 90 00 31
3B 9F 97 80 3F C7 82 80 31 E0 73 FE 21 1F 64 08 63 62 00 82 90 00 6F
3B 9F 97 C0 0A 3F C7 82 80 31 E0 73 FE 21 1F 65 D0 02 1A 14 A2 81 0F CF
3B 9F 96 80 3F C7 82 80 31 E0 73 F6 21 57 57 4A 4D 02 0B 60 50 00 38
开启高通diag端口
MOTO X30
setprop sys.usb.config diag,serial_cdev,rmnet,adb
纯Python的Web UI
只需要懂Python就可以了,不再需要学习 JavaScript HTML CSS
NiceGUI
NiceGUI httpx coroutine button click
import asyncio import httpx from nicegui import ui async def add(url): print('----') l = ui.label('This should be visible') async with httpx.AsyncClient() as client: r = await client.get(url) res = r.json() l.text = res['ip'] ip_url = 'https://api.seeip.org/jsonip' #ip_url = 'https://api.ipify.org/?format=json' ui.button('Add label', on_click= lambda:add(ip_url)) ui.run(reload=False, host="::", port=5678, favicon='🚀', title='httpx协程')
报错
RuntimeWarning: coroutine 'add' was never awaited self.on('click', lambda _: handle_event(on_click, ClickEventArguments(sender=self, client=self.client))) RuntimeWarning: Enable tracemalloc to get the object allocation traceback
修改成不带参数的
import asyncio import httpx from nicegui import ui #ip_url = 'https://api.seeip.org/jsonip' ip_url = 'https://api.bigdatacloud.net/data/client-ip' async def add(): print('----') l = ui.label('Waiting...') async with httpx.AsyncClient() as client: r = await client.get(ip_url) res = r.json() l.text = res['ipString'] ui.button('Get IP', on_click=add) ui.run(reload=False, host="::", port=5678, favicon='🚀', title='httpx协程')
真有传递参数,还是有办法的
How to pass an argument to an async function with a ui.button
import asyncio import httpx from nicegui import ui from functools import partial ip_url = 'https://api.seeip.org/jsonip' #ip_url = 'https://ipv6.jsonip.com/' # https://ipv4.jsonip.com/ # http://no-tls.jsonip.com/ async def add(url): print('----') l = ui.label('Waiting...') async with httpx.AsyncClient() as client: r = await client.get(url) res = r.json() l.text = res['ip'] ui.button('Get IP', on_click=partial(add, ip_url)) ui.run(reload=False, host="::", port=5678, favicon='🚀', title='httpx协程')
就是用 functools 的 partial
SubscriptionManager
boolean setSubscriptionEnabled(int subscriptionId, boolean enable)
首先检查 canDisablePhysicalSubscription
public static int getSubscriptionId(int slotIndex)
boolean isSubscriptionEnabled(int subscriptionId)
public SubscriptionInfo getActiveSubscriptionInfoForSimSlotIndex (int slotIndex)
getSubscriptionId()
Jetpack Compose
@Composable fun TextDemo() { Column(modifier = Modifier.fillMaxSize()) { var text by remember { mutableStateOf("Hello, World!") } Button(onClick = { text = "Good" }) { Text(text = "Go") } Text(text) } }
点击button, 修改text
Android SIM卡pass through模式
将SIM卡先Power Down, 然后在Power up pass through, 就可以将 SIM设置为直通(pass through)模式.
当初sim卡处于直通模式时,modem不发送其他任何指令(包括选择MF文件,TERMINAL CAPABILITY)。sim卡完全被Telephony控制, 直接发送 APDU. SIM卡的状态,将被设置为RIL_CARDSTATE_PRESENT, card apps的数目将是0. 不会生成任何错误代码。紧急呼叫将被支持,就如同SIM不存在时,也可以支持紧急呼叫那样。
直通模式,只对 激活它的 特定会话 有效。当卡下次初始化时, 就回到普通模式,除非你 再次请求直通模式。也就是说,手机重启后, SIM卡将回到 正常模式。
调用者应该监视 TelephonyIntents#ACTION_SIM_STATE_CHANGED 广播,来决定 成功或者失败,以及是否超时. 但新设备上,不保证会触发 广播。 请用新接口 setSimPowerState(int, Executor, Consumer_integer)
回调可能的值:
SET_SIM_POWER_STATE_SUCCESS
SET_SIM_POWER_STATE_ALREADY_IN_STATE
SET_SIM_POWER_STATE_MODEM_ERROR
SET_SIM_POWER_STATE_SIM_ERROR
SET_SIM_POWER_STATE_NOT_SUPPORTED
如果请求的 sim卡状态不对,将抛出 IllegalArgumentException 异常。
platform/hardware/interfaces/+/master/radio/1.6/IRadio.hal
oneway setSimCardPower_1_6(int32_t serial, CardPowerState powerUp);
设置SIM卡电源状态。
请求关掉 或者打开 sim卡的电源。
它不应该生成一个 CardState.CARDSTATE_ABSEND指示。
因为SIM卡还是物理插入在卡槽的。
当SIM卡处于直通模式时, modem不发送任何指定给sim卡,(比如
SELECT MF或者TERMINAL CAPABILITY指令)。SIM卡完全被
Telephony控制发送APDU.
SIM卡的状态必须是 RIL_CAFDSTATE_PERSENT
卡上的apps数量将为0
不会生成新的错误代码。
在切换为POWER_UP/POWE_UP_PASS_THROUGH状态前,SIM卡必须处于power down.
在手机power up时, SIM卡接口也会自动power up
关sim,开sim,这些请求,必须等前一个请求完成后,才能处理。
关卡状态,在CardStatus.applicaont中, modem发送一个空的AppStatus向量。
在关卡状态是,如果物理移除并插入新的sim卡,新卡必须默认处于开卡状态。
oneway setSimCardPower_1_1(int32_t serial, CardPowerState powerUp);
hardware/interfaces/radio/aidl/android/hardware/radio/sim/IRadioSim.aidl
void setSimCardPower(in int serial, in CardPowerState powerUp);
Android Print stacktrace using Frida
console.log(Java.use("android.util.Log").getStackTraceString(Java.use("java.lang.Exception").$new()))
SGP.22 eUICC信息
EUICCInfo1是EUICCInfo2的子集。
EUICCInfo1 是在 卡片被 authenticated前,发送给RSP服务器的信息。
EUICCInfo2 是卡片完整的信息, 只有euicc和rsp双方相互认证完成后,才会发给RSP.
LPA可以在任何时候向 euicc取得这些信息。
Profile Package Versions 包版本 Specification Version Numbers 规范版本 Firmware version 固件版本 Available amount of non-volatile memory 可用的存储空间大小 UICC capabilities 能力 ETSI TS 102 241 version 102.241规范版本 GlobalPlatform version GP版本 RSP capabilities RSP能力 Lists of supported eSIM CA RootCA Public Key Identifiers 支持的根证书公钥标识符 列表 eUICC Category 类别 Forbidden PPRs Protection Profile version SAS Accreditation Number Certification Data Object TRE properties TRE product reference LPA Mode EUM specific information