Android中 获取手机通讯录和手机机主手机号码

简介: Android中 获取手机通讯录和手机机主手机号码

1.获取手机机主手机号码

目标:获取手机机主手机号码

(注:我只给出了代码思路和用法示例,大家可以自己调用方法debug运行看结果或者自行编写显示结果的代码,根据需要进行修改,希望对您有帮助!)

eg:

public class ContactUtils {
    private static TelephonyManager telephonyManager;
    /**
     * 获取本地SIM卡手机机主号码
     * 
     * @return
     */
    public static String getNativePhoneNumber(Context cxt) {
      telephonyManager = (TelephonyManager) cxt
          .getSystemService(Context.TELEPHONY_SERVICE);
      String NativePhoneNumber = null;
      NativePhoneNumber = telephonyManager.getLine1Number();
      return NativePhoneNumber;
    }
  }

2.获取手机通讯录


目标:获取手机通讯录联系人的姓名和手机号码,屏幕座机和其他非手机号码,避免号码重复


(注:我只给出了代码思路和用法示例,大家可以自己调用方法debug运行看结果或者自行编写显示结果的代码,根据需要进行修改,希望对您有帮助!)


eg:

/**
 * 获取手机通讯录
 * 只获取正确非重复手机号码
 * @author 诺诺
 * 
 */
public class ContactUtils {
  private static final String TAG = "ContactList";
  // 获取系统数据库联系人Phone表字段信息
  private static final String[] phoneContact = new String[] {
      Phone.CONTACT_ID, Phone.DISPLAY_NAME, Phone.NUMBER, Photo.PHOTO_ID };
  // 联系人的ID
  private static final int contactID_Contact = 0;
  // 联系人名称
  private static final int name_Contact = 1;
  // 电话号码
  private static final int num_Contact = 2;
  // 头像ID
  private static final int phoneID_Contact = 3;
  /**
   * 获取手机联系人信息:只获取正确非重复手机号
   * @param context
   * @return ArrayList
   */
  public static ArrayList<ContactInfo> getContactsList(Context context) {
    ContentResolver resolver = context.getContentResolver();
    Cursor phoneCursor = resolver.query(Phone.CONTENT_URI, phoneContact,
        null, null, ContactsContract.Contacts.DISPLAY_NAME
            + " COLLATE LOCALIZED ASC");
    // <name,ContactInfo>
    HashMap<String, ContactInfo> nameMap = new HashMap<String, ContactInfo>();
    // 通讯录的所有手机号码
    ArrayList<String> phoneList = new ArrayList<String>();
    if (phoneCursor != null) {
      //通讯录所有联系人信息
      ArrayList<ContactInfo> contacts = new ArrayList<ContactInfo>();
      ContactInfo contactInfo = null;
      while (phoneCursor.moveToNext()) {
        // 得到手机号码
        String phoneNumber = phoneCursor.getString(num_Contact);
        Log.i(TAG + " phoneNumber: ", phoneNumber);
        // 当手机号码为空的或非正确手机号 跳过此次循环
        if (TextUtils.isEmpty(phoneNumber)
            || !RegexUtils.isMoblieNo(phoneNumber)){
          continue;
        }
        // 得到联系人名称
        String contactName = phoneCursor.getString(name_Contact);
        // 得到联系人ID
        int contactid = phoneCursor.getInt(contactID_Contact);
        // 得到联系人头像ID
        Long photoid = phoneCursor.getLong(phoneID_Contact);
        if (phoneList.contains(phoneNumber)) {
          continue;
        } else {
          phoneList.add(phoneNumber);
          if (!nameMap.containsKey(contactName)) {
            contactInfo = new ContactInfo();
            contactInfo.name = contactName;
            contactInfo.mobilePhoneList.add(phoneNumber);
            contacts.add(contactInfo);
            nameMap.put(contactName, contactInfo);
          } else {
            contactInfo = nameMap.get(contactName);
            contactInfo.mobilePhoneList.add(phoneNumber);
          }
        }
      }
      phoneCursor.close();
      return contacts;
    }
    return null;
  }
  /**
   * 联系人信息类
   */
  public static class ContactInfo implements Serializable {
    public String name; // 联系人姓名
    public ArrayList<String> mobilePhoneList; // 手机号码
    public ContactInfo() {
      CheckNullPointer();
    }
    /**
     * 避免发生空指针异常
     */
    public void CheckNullPointer() {
      if (mobilePhoneList == null)
        mobilePhoneList = new ArrayList<String>();
      if (name == null)
        name = "";
    }
    public String getName() {
      return name;
    }
    public void setName(String name) {
      this.name = name;
    }
    public ArrayList<String> getPhoneNumList() {
      return mobilePhoneList;
    }
    public void setPhoneNumList(ArrayList<String> mobilePhone) {
      mobilePhoneList = mobilePhone;
    }
  }
}
public class RegexUtils {
  /**
   * 验证是否是有效手机号
   * 
   *  移动:134、135、136、137、138、139、150、151、157(TD)、158、159、187、188
   * 
   *   联通:130、131、132、152、155、156、185、186
   * 
   *   电信:133、153、180、189、(1349卫通)
   * 
   * @param mobiles
   * @return
   */
  public static boolean isMoblieNo(String mobiles) {
    Pattern p = Pattern
        .compile("^((13[0-9])|(15[^4,\\D])|(18[0,5-9]))\\d{8}$");
    Matcher m = p.matcher(mobiles);
    return m.matches();
  }
}
目录
相关文章
|
7月前
|
网络协议 Android开发 数据安全/隐私保护
Android手机上使用Socks5全局代理-教程+软件
Android手机上使用Socks5全局代理-教程+软件
5190 2
|
2月前
|
Android开发 数据安全/隐私保护 虚拟化
安卓手机远程连接登录Windows服务器教程
安卓手机远程连接登录Windows服务器教程
127 4
|
3月前
|
Ubuntu Linux Android开发
termux+anlinux+Rvnc viewer来使安卓手机(平板)变成linux服务器
本文介绍了如何在Android设备上安装Termux和AnLinux,并通过这些工具运行Ubuntu系统和桌面环境。
203 2
termux+anlinux+Rvnc viewer来使安卓手机(平板)变成linux服务器
|
2月前
|
安全 搜索推荐 Android开发
Android vs. iOS:解锁智能手机操作系统的奥秘####
【10月更文挑战第21天】 在当今这个数字化时代,智能手机已成为我们生活中不可或缺的伙伴。本文旨在深入浅出地探讨两大主流操作系统——Android与iOS的核心差异、优势及未来趋势,帮助读者更好地理解这两个平台背后的技术哲学和用户体验设计。通过对比分析,揭示它们如何塑造了我们的数字生活方式,并展望未来可能的发展路径。无论您是技术爱好者还是普通用户,这篇文章都将带您走进一个充满创新与可能性的移动世界。 ####
98 3
|
3月前
|
Web App开发 Android开发
利用firefox调试安卓手机端web
该教程详细介绍如何通过Firefox浏览器实现手机与电脑的远程调试。手机端需安装最新版Firefox,并按指定步骤设置完成;电脑端则需安装15版及以上Firefox。设置完成后,通过工具栏中的“远程调试”选项,输入手机IP地址即可连接。连接确认后,即可使用电脑端Firefox调试器调试手机上的Web信息。注意,调试前手机需提前打开目标网页。
114 2
|
3月前
|
Android开发 iOS开发 UED
安卓与iOS的较量:谁才是智能手机市场的王者?
本文将深入探讨安卓和iOS两大智能手机操作系统之间的竞争关系,分析它们各自的优势和劣势。通过对比两者在市场份额、用户体验、应用生态等方面的表现,我们将揭示出谁才是真正的市场领导者。无论你是安卓粉丝还是iOS忠实用户,这篇文章都将为你提供一些有趣的观点和见解。
|
5月前
|
存储 数据可视化 C语言
【C语言】C语言 手机通讯录系统的设计 (源码+数据+论文)【独一无二】
【C语言】C语言 手机通讯录系统的设计 (源码+数据+论文)【独一无二】
|
5月前
|
Android开发
【Azure 环境】记录使用Notification Hub,安卓手机收不到Push通知时的错误,Error_Code 30602 or 30608
【Azure 环境】记录使用Notification Hub,安卓手机收不到Push通知时的错误,Error_Code 30602 or 30608
|
6月前
|
存储 移动开发 Android开发
使用kotlin Jetpack Compose框架开发安卓app, webview中h5如何访问手机存储上传文件
在Kotlin和Jetpack Compose中,集成WebView以支持HTML5页面访问手机存储及上传音频文件涉及关键步骤:1) 添加`READ_EXTERNAL_STORAGE`和`WRITE_EXTERNAL_STORAGE`权限,考虑Android 11的分区存储;2) 配置WebView允许JavaScript和文件访问,启用`javaScriptEnabled`、`allowFileAccess`等设置;3) HTML5页面使用`<input type="file">`让用户选择文件,利用File API;
|
5月前
|
Java Android开发 UED
安卓scheme_url调端:如果手机上多个app都注册了 http或者https 的 intent。 调端的时候,调起哪个app呢?
当多个Android应用注册了相同的URL Scheme(如http或https)时,系统会在尝试打开这类链接时展示一个选择对话框,让用户挑选偏好应用。若用户选择“始终”使用某个应用,则后续相同链接将直接由该应用处理,无需再次选择。本文以App A与App B为例,展示了如何在`AndroidManifest.xml`中配置对http与https的支持,并提供了从其他应用发起调用的示例代码。此外,还讨论了如何在系统设置中管理这些默认应用选择,以及建议开发者为避免冲突应注册更独特的Scheme。