MTK平台获取本机的SIM卡中IMSI号

2023-10-28 05:08

本文主要是介绍MTK平台获取本机的SIM卡中IMSI号,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

要求在MTK的代码上获得本机上SIM卡的手机号码,查了很多资料后,结果是无法获得,原因是手机号码不是直接存储在SIM卡的,而是信号通过移动商(移动、联通或电信)时绑定的;IMSI是sim卡的一个属性号,在移动系统中是跟sim卡号绑定的,开户之后跟手机号绑定,开户的过程就是将你的IMSI和手机号发给交换机HLR,这样子来电话的时候交换机就可以找到了。

其次,利用SIM的“ID号”也可以唯一标识一个用户,只是SIM可以补办,考虑统一电话号码不对应补办后的SIM卡信息,所以不是太好,但是无法得到手机号码,也只能先这么做了。

 

在实现方面,SIM卡中信息IMSI号的获得,是轻而易举的,远比获得手机号码简单地多,下面就是我的详细实现方法(有两种方法):

      第一种方法:

      void our_send_msg_get_imsi(void)                //从MMI层想L4C层发送消息
     {
          MYQUEUE Message;       
          SetProtocolEventHandler(our_sim_imsi_rsp, PRT_GET_IMSI_RSP);           //给PRT_GET_IMSI_RSP消息绑定一个函数
          Message.oslSrcId = MOD_MMI;   //发送消息源模块
          Message.oslDestId = MOD_L4C;    //消息的目的模块
          Message.oslMsgId = PRT_GET_IMSI_REQ;     //消息的ID
          Message.oslDataPtr = NULL;       //消息的携带数据
          Message.oslPeerBuffPtr = NULL;     
          OslMsgSendExtQueue(&Message);     //发送消息到外部队列
          kal_prompt_trace(MOD_MMI,"btl_send_msg_get_imsi");
      }


      void our_sim_imsi_rsp(void *info)       //PRT_GET_IMSI_RSP消息发生时会自动调用的函数
     {
           char imsi_imei_num[17];      //定义存放IMSI号的字符数组:IMSI号不多于15位,但是模拟器上会得到16位数字加一位结束符
           mmi_smu_get_imsi_rsp_struct *local_data = (mmi_smu_get_imsi_rsp_struct*) info;   //得到的信息内容
           kal_prompt_trace(MOD_MMI,"btl_sim_imsi_rsp1");     //在Catcher中显示的
           strcpy(imsi_imei_num,(char*)local_data->imsi);     //将SIM存放在数组中
    _cprintf("the imsi number is : %s/n",imsi_imei_num);  //在控制台打印出获得的IMSI号
           kal_prompt_trace(MOD_MMI,"btl_sim_imsi_rsp2");
      }


      函数声明后,在任意文件的任意位置调用函数btl_send_get_imsi()即可,当系统有消息PRT_GET_IMSI_RSP发生时,就会调用函数btl_sim_imsi_rsp(),该函数的参数是消息PRT_GET_IMSI_RSP发生时所传过来的数据,是系统自动传参给该函数的。这样就可以获得到本机SIM卡的IMSI号了。

      第二种方法是:定义事件捕获函数,捕获系统都有什么时间发生,当某一事件(例如来电事件、拒接事件、短信事件等等)发生时就会捕获到,我们可以自己做些自己的处理。

       1)定义事件捕获函数:   FlySky_EventHook(unsigned short ID,void *pMsg)

        void FlySky_EventHook(unsigned short ID,void *pMsg)

        {

              char imsiNum[17];

              char phoneNUm[20];

               memset(&imsiNum,0,sizeof(imsiNum));                   //初始化数组为'/0',以保证后面赋值的正确性

               memset(&phoneNum,0,0, sizeof(phoneNUm));       //同上

               switch(ID)

                {

                       case PRT_INCOMINGCALL_EVENT:             //来电事件发生

                        {

                              IncomingCall  flysky_msg;

                               /* Get  the incoming call number */

                               memset(&flysky_msg, 0,sizeof(flysky_msg));   //初始化结构体flysky_msg,以免获得信息后赋值不正确

                               DeriveCallInfo(pMsg, &flysky_msg);         // 转换L4来电事件为IncomingCall结构事件

                               strcpy(phoneNum,(const char *)flysky_msg.Number);   //得到来电的电话号码

                               /* Test to get the IMSI*/

                               our2_send_msg_get_imsi();            //利用来电事件来测试,来电时发送消息给L4C层

                              

                        }

                       case PRT_INCOMINGCALL_REJECTED:       //拒接来电

                        {

                               break;

                         }

                       case PRT_GET_IMSI_RSP:        //得到IMSI请求回复

                        {

                                our2_sim_imsi_rsp(pMsg);    //将该消息发生时的数据信息传参给btl_sim_imsi_rsp

                                break;

                        }

                       default:

                              break;

                }

        }

       void our2_send_msg_get_imsi(void)
      {
            MYQUEUE Message;


            //SetProtocolEventHandler(btl_sim_imsi_rsp, PRT_GET_IMSI_RSP);


            Message.oslSrcId = MOD_MMI;
            Message.oslDestId = MOD_L4C;
            Message.oslMsgId = PRT_GET_IMSI_REQ;
            Message.oslDataPtr = NULL;
            Message.oslPeerBuffPtr = NULL;
            OslMsgSendExtQueue(&Message);
            kal_prompt_trace(MOD_MMI,"btl_send_msg_get_imsi");
       }

 

       void our2_sim_imsi_rsp(void *info)
       {
            char imsi_imei_num[17];
            mmi_smu_get_imsi_rsp_struct *local_data = (mmi_smu_get_imsi_rsp_struct*) info;
            kal_prompt_trace(MOD_MMI,"btl_sim_imsi_rsp1");
            strcpy(imsi_imei_num,(char*)local_data->imsi);
            kal_prompt_trace(MOD_MMI,"btl_sim_imsi_rsp2");
       }


       首先要将函数FlySky_EventHook()在MMITask.c文件MMI_task函数前进行声明:extern void FlySky_EventHook(unsigned short ID, void* pMsg);  然后在函数MMI_task的“default: ProtocolEventHandler()”和“break”之间加上:FlySky_EventHook(Message.oslMsgId, (void*)Message.oslDataPtr);

  

       这样就可以捕获到系统所有事件了,想要对什么时间进行捕获,直接在FlySky_EventHook中的case出给出事件对应的消息即可,并对该消息下的事件进行相应的处理即可。

      说明:在MTK平台获得IMSI号是比较容易获得的,但是在模拟器中获得的是16位数字的字符串,网上资料中可以查到IMSI(国际移动用户标识符)不超过15位,即是15位组成的,原因是,在模拟器上的并不是真正的SIM卡,所以,要做真正的测试,还需要烧录到真机上进行一个测试.

这篇关于MTK平台获取本机的SIM卡中IMSI号的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/290897

相关文章

流媒体平台/视频监控/安防视频汇聚EasyCVR播放暂停后视频画面黑屏是什么原因?

视频智能分析/视频监控/安防监控综合管理系统EasyCVR视频汇聚融合平台,是TSINGSEE青犀视频垂直深耕音视频流媒体技术、AI智能技术领域的杰出成果。该平台以其强大的视频处理、汇聚与融合能力,在构建全栈视频监控系统中展现出了独特的优势。视频监控管理系统EasyCVR平台内置了强大的视频解码、转码、压缩等技术,能够处理多种视频流格式,并以多种格式(RTMP、RTSP、HTTP-FLV、WebS

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听

如何解决线上平台抽佣高 线下门店客流少的痛点!

目前,许多传统零售店铺正遭遇客源下降的难题。尽管广告推广能带来一定的客流,但其费用昂贵。鉴于此,众多零售商纷纷选择加入像美团、饿了么和抖音这样的大型在线平台,但这些平台的高佣金率导致了利润的大幅缩水。在这样的市场环境下,商家之间的合作网络逐渐成为一种有效的解决方案,通过资源和客户基础的共享,实现共同的利益增长。 以最近在上海兴起的一个跨行业合作平台为例,该平台融合了环保消费积分系统,在短

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

【区块链 + 人才服务】区块链集成开发平台 | FISCO BCOS应用案例

随着区块链技术的快速发展,越来越多的企业开始将其应用于实际业务中。然而,区块链技术的专业性使得其集成开发成为一项挑战。针对此,广东中创智慧科技有限公司基于国产开源联盟链 FISCO BCOS 推出了区块链集成开发平台。该平台基于区块链技术,提供一套全面的区块链开发工具和开发环境,支持开发者快速开发和部署区块链应用。此外,该平台还可以提供一套全面的区块链开发教程和文档,帮助开发者快速上手区块链开发。

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

衡石分析平台使用手册-单机安装及启动

单机安装及启动​ 本文讲述如何在单机环境下进行 HENGSHI SENSE 安装的操作过程。 在安装前请确认网络环境,如果是隔离环境,无法连接互联网时,请先按照 离线环境安装依赖的指导进行依赖包的安装,然后按照本文的指导继续操作。如果网络环境可以连接互联网,请直接按照本文的指导进行安装。 准备工作​ 请参考安装环境文档准备安装环境。 配置用户与安装目录。 在操作前请检查您是否有 sud

业务协同平台--简介

一、使用场景         1.多个系统统一在业务协同平台定义协同策略,由业务协同平台代替人工完成一系列的单据录入         2.同时业务协同平台将执行任务推送给pda、pad等执行终端,通知各人员、设备进行作业执行         3.作业过程中,可设置完成时间预警、作业节点通知,时刻了解作业进程         4.做完再给你做过程分析,给出优化建议         就问你这一套下

容器编排平台Kubernetes简介

目录 什么是K8s 为什么需要K8s 什么是容器(Contianer) K8s能做什么? K8s的架构原理  控制平面(Control plane)         kube-apiserver         etcd         kube-scheduler         kube-controller-manager         cloud-controlle