android 双卡手机发短信/判断手机是否为双卡
通过反射发现sendMultipartTextMessage多了一个phoneType的参数,这个参数就是这只用GMS还是CDMA卡发送的。
phoneType获取方法,iTelephony.getActivePhoneType();//1=GSM,2=CDMA
- try {
- Class<?> smsManagerClass = null;
- Class[] divideMessagePamas = { String.class };
- Class[] sendMultipartTextMessagePamas = { String.class,String.class,
ArrayList.class, ArrayList.class,ArrayList.class, int.class }; - Method divideMessage = null;
- Method sendMultipartTextMessage = null;
- smsManagerClass = Class.forName("android.telephony.SmsManager");
- Method method = smsManagerClass.getMethod("getDefault", new
Class[]{}); - Object smsManager = method.invoke(smsManagerClass, new Object[]{});
- divideMessage =
smsManagerClass.getMethod("divideMessage",divideMessagePamas); - sendMultipartTextMessage =
smsManagerClass.getMethod("sendMultipartTextMessage",
sendMultipartTextMessagePamas); - ArrayList<String> magArray = (ArrayList<String>)
divideMessage.invoke(smsManager, content); - sendMultipartTextMessage.invoke(smsManager,phone, "", magArray,
null, null,phoneType); - } catch (IllegalArgumentException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- } catch (IllegalAccessException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- } catch (InvocationTargetException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- } catch (ClassNotFoundException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- } catch (SecurityException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- } catch (NoSuchMethodException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
判断手机是否为双卡:
- public static void initIsDoubleTelephone(Context context){
- boolean isDouble = true;
- Method method = null;
- Object result_0 = null;
- Object result_1 = null;
- TelephonyManager tm = (TelephonyManager)
context.getSystemService(Context.TELEPHONY_SERVICE); - try {
- //只要在反射getSimStateGemini 这个函数时报了错就是单卡手机(这是我自己的经验,不一定全正确)
- method = TelephonyManager.class.getMethod("getSimStateGemini",new Class[] {
int.class }); - //获取SIM卡1
- result_0 = method.invoke(tm, new Object[] { new Integer(0) });
- //获取SIM卡1
- result_1 = method.invoke(tm, new Object[] { new Integer(1) });
- } catch (SecurityException e) {
- isDouble = false;
- e.printStackTrace();
- //System.out.println("1_ISSINGLETELEPHONE:"+e.toString());
- } catch (NoSuchMethodException e) {
- isDouble = false;
- e.printStackTrace();
- //System.out.println("2_ISSINGLETELEPHONE:"+e.toString());
- } catch (IllegalArgumentException e) {
- isDouble = false;
- e.printStackTrace();
- } catch (IllegalAccessException e) {
- isDouble = false;
- e.printStackTrace();
- } catch (InvocationTargetException e) {
- isDouble = false;
- e.printStackTrace();
- } catch (Exception e){
- isDouble = false;
- e.printStackTrace();
- //System.out.println("3_ISSINGLETELEPHONE:"+e.toString());
- }
- SharedPreferences sp =
PreferenceManager.getDefaultSharedPreferences(context); - Editor editor = sp.edit();
- if(isDouble){
- //保存为双卡手机
- editor.putBoolean(ISDOUBLE, true);
- //保存双卡是否可用
- //如下判断哪个卡可用.双卡都可以用
- if(result_0.toString().equals("5") &&
result_1.toString().equals("5")){ - if(!sp.getString(SIMCARD, "2").equals("0") && !sp.getString(SIMCARD,
"2").equals("1")){ - editor.putString(SIMCARD, "0");
- }
- editor.putBoolean(SIMCARD_1, true);
- editor.putBoolean(SIMCARD_2, true);
- } else if(!result_0.toString().equals("5") &&
result_1.toString().equals("5")){//卡二可用 - if(!sp.getString(SIMCARD, "2").equals("0") && !sp.getString(SIMCARD,
"2").equals("1")){ - editor.putString(SIMCARD, "1");
- }
- editor.putBoolean(SIMCARD_1, false);
- editor.putBoolean(SIMCARD_2, true);
- } else if(result_0.toString().equals("5") &&
!result_1.toString().equals("5")){//卡一可用 - if(!sp.getString(SIMCARD, "2").equals("0") && !sp.getString(SIMCARD,
"2").equals("1")){ - editor.putString(SIMCARD, "0");
- }
- editor.putBoolean(SIMCARD_1, true);
- editor.putBoolean(SIMCARD_2, false);
- } else {//两个卡都不可用(飞行模式会出现这种种情况)
- editor.putBoolean(SIMCARD_1, false);
- editor.putBoolean(SIMCARD_2, false);
- }
- }else{
- //保存为单卡手机
- editor.putString(SIMCARD, "0");
- editor.putBoolean(ISDOUBLE, false);
- }
- editor.commit();
- }
android 双卡手机发短信/判断手机是否为双卡的更多相关文章
- 向android模拟器打电话发短信的简单方法
在开发android应用程序时,有时候需要测试一下向android手机拨打电话发送短信时该应用程序的反应.譬如编写一个广播接收器,来提示用户有短信收到或者处理短信,就需要向该手机发送短信来进行测试.这 ...
- android打电话、发短信实现
打电话: Intent intent = newIntent(Intent.ACTION_CALL,Uri.parse("tel:"+"156666666666" ...
- Android——SMS接收发短信与运行权限
好久没写了,最近学习Android的相关知识,包括UI组件与布局.Activity生命周期等,而这次要讲的是,Broadcast Receiver的相关知识,主要是接收发短信,SmsManager.S ...
- 如何向Android模拟器打电话发短信
1. 启动Android Emulator, 查看标题栏找出端口.一般是android emulator(5554),其中5554就是端口. 2. 打开命令行,输入telnet localhost 5 ...
- 【转】如何向Android模拟器打电话发短信
转载地址:http://hi.baidu.com/jeremylai/item/420f9c9fe4881fccb62531f7 1. 启动Android Emulator, 查看标题栏找出端口.一般 ...
- 使用Python往手机发送短信(基于twilio模块)
官网是https://www.twilio.com twilio的一句话介绍——提供SDK帮你连接世界上所有人,你可以很方便的调用他们提供的接口来给指定手机发短信,打电话. 首先在twilio的官网注 ...
- Android Tips: 打电话和发短信
利用Android打电话非常简单,直接调用Android内在的电话功能就可以了. btnDail.setOnClickListener(new OnClickListener(){ @Override ...
- 【319】Python 通过 Twilio 发短信
参考:python利用twilio模块给自己发短信 参考:使用python实现往手机发短信(基于twilio) 步骤如下: 登录 Twilio 网站注册,貌似需要***,包括用户名.密码.手机号.项目 ...
- Android实例-打电话、发短信和邮件,取得手机IMEI号(XE8+小米2)
结果: 1.不提示发短信卡住,点击没有反映,我猜想,可能是因为我用的是小米手机吧. 2.接收短信报错,我猜想可能是我改了里面的方法吧(哪位大神了解,求指教). 3.project -->opti ...
随机推荐
- tomcat https 配置
以前基本上笔者对于安全性考虑的并不多,最近因为saas平台要开始逐渐推广,所以需要开始逐渐加强xss/crsf/https等措施以避免潜在的安全性风险.本文简单的记录下tomcat下https的配置. ...
- 定位- CLGeoencoder - 反编码
#import "ViewController.h" #import "MBProgressHUD+MJ.h" #import <CoreLocation ...
- C#中通过调用Dll函数时,执行一段时间后,就会报内存可能被破坏的错的解决办法
遇到同样的问题,已经解决的:http://blog.csdn.net/youxiazzz12/article/details/24313347
- nutch http file 截断问题
问题: 列表页预计抽取 355+6 但实际只抽取到220条链接. 原因是nutch对http下载的内容的长度进行了限制. 解决方案:这里将这个属性扩大10倍. vim conf/nutch-defal ...
- Linux find命令详解
转自Linux find命令详解 一.find 命令格式 1.find命令的一般形式为: find pathname -options [-print -exec -ok ...] 2.find命令的 ...
- tornado异步请求的理解(转)
tornado异步请求的理解 http://www.kankanews.com/ICkengine/archives/88953.shtml 官网第一段话: Tornado is a Python w ...
- SPRING IN ACTION 第4版笔记-第二章-001-用@Autowired\@ComponentScan、@Configuration、@Component实现自动装载bean
1. package soundsystem; import org.springframework.context.annotation.ComponentScan; import org.spri ...
- SpringMVC源码解析 - HandlerMethod
HandlerMethod及子类主要用于封装方法调用相关信息,子类还提供调用,参数准备和返回值处理的职责. 分析下各个类的职责吧(顺便做分析目录): HandlerMethod 封装方法定义相关的信息 ...
- [OJ] Matrix Zigzag Traversal
LintCode #46. Matrix Zigzag Traversal (Easy) class Solution { public: vector<int> printZMatrix ...
- IPVS实现分析
IPVS实现分析 IPVS实现分析 根据LVS官方网站的介绍,LVS支持三种负载均衡模式:NAT,tunnel和direct routing(DR). NAT是通用模式,所有交互数据必须通过均衡器:后 ...