首页 > 代码库 > 【小功能2】android获取手机信息(号码,内存,CPU,分辨率,MAC,IP,SD卡,IMEI,经纬度,信号强度等等)
【小功能2】android获取手机信息(号码,内存,CPU,分辨率,MAC,IP,SD卡,IMEI,经纬度,信号强度等等)
为了实现一个功能,需要搜集手机信息,自己先在网上找了相关信息进行了汇总,主要是汇集手机的信息,一般想要的信息在手机设置->关于手机->状态消息里面包含了手机的各种信息,下面的代码中也主要显示了那些信息,但是源码的方法我还没有看,先把总结的贴出来。先上图(太多就截取几个)。
上代码啦,太多了,就写主要代码了。
- // 获取Android手机中SD卡存储信息 获取剩余空间
- public void getSDCardInfo() {
- // 在manifest.xml文件中要添加
- /*
- * <uses-permission
- * android:name="android.permission.WRITE_EXTERNAL_STORAGE">
- * </uses-permission>
- */
- // 需要判断手机上面SD卡是否插好,如果有SD卡的情况下,我们才可以访问得到并获取到它的相关信息,当然以下这个语句需要用if做判断
- if (Environment.getExternalStorageState().equals(
- Environment.MEDIA_MOUNTED)) {
- // 取得sdcard文件路径
- File path = Environment.getExternalStorageDirectory();
- StatFs statfs = new StatFs(path.getPath());
- // 获取block的SIZE
- long blocSize = statfs.getBlockSize();
- // 获取BLOCK数量
- long totalBlocks = statfs.getBlockCount();
- // 空闲的Block的数量
- long availaBlock = statfs.getAvailableBlocks();
- // 计算总空间大小和空闲的空间大小
- // 存储空间大小跟空闲的存储空间大小就被计算出来了。
- long availableSize = blocSize * availaBlock;
- // (availableBlocks * blockSize)/1024 KIB 单位
- // (availableBlocks * blockSize)/1024 /1024 MIB单位
- long allSize = blocSize * totalBlocks;
- }
- }
- // 获取手机ip method-1
- public String getLocalIpAddress() {
- try {
- for (Enumeration<NetworkInterface> en = NetworkInterface
- .getNetworkInterfaces(); en.hasMoreElements();) {
- NetworkInterface intf = en.nextElement();
- for (Enumeration<InetAddress> enumIpAddr = intf
- .getInetAddresses(); enumIpAddr.hasMoreElements();) {
- InetAddress inetAddress = enumIpAddr.nextElement();
- if (!inetAddress.isLoopbackAddress()) {
- Toast.makeText(this,
- inetAddress.getHostAddress().toString(), 3000)
- .show();
- return inetAddress.getHostAddress().toString();
- }
- }
- }
- } catch (SocketException ex) {
- ex.printStackTrace();
- // Log.e("ifo", ex.toString());
- }
- return "";
- } // 需要权限<uses-permission
- // android:name="android.permission.ACCESS_WIFI_STATE"></uses-permission>
- // <uses-permission
- // android:name="android.permission.INTERNET"></uses-permission>
- // 获取手机ip method-2
- // 首先设置用户权限
- // <uses-permission
- // android:name="android.permission.ACCESS_WIFI_STATE"></uses-permission>
- // <uses-permission
- // android:name="android.permission.CHANGE_WIFI_STATE"></uses-permission>
- // <uses-permission
- // android:name="android.permission.WAKE_LOCK"></uses-permission>
- public String getLocalIpAddress2() {
- // 获取wifi服务
- WifiManager wifiManager = (WifiManager) getSystemService(Context.WIFI_SERVICE);
- // 判断wifi是否开启
- if (!wifiManager.isWifiEnabled()) {
- wifiManager.setWifiEnabled(true);
- }
- WifiInfo wifiInfo = wifiManager.getConnectionInfo();
- int ipAddress = wifiInfo.getIpAddress();
- String ip = intToIp(ipAddress);
- return ip;
- }
- private String intToIp(int i) {
- return (i & 0xFF) + "." + ((i >> 8) & 0xFF) + "." + ((i >> 16) & 0xFF)
- + "." + (i >> 24 & 0xFF);
- }
- // 查看本机外网IP
- /*
- * 该方法需要设备支持上网 查看
- * System.out.println((GetNetIp("http://fw.qq.com/ipaddress"))); 加权限
- * <uses-permission
- * android:name="android.permission.INTERNET"></uses-permission>
- * 通过获取http://fw.qq.com/ipaddress网页取得外网IP 这里有几个查看IP的网址然后提取IP试试。
- * http://ip168.com/ http://www.cmyip.com/ http://city.ip138.com/ip2city.asp
- */
- public String GetNetIp(String ipaddr) {
- URL infoUrl = null;
- InputStream inStream = null;
- try {
- infoUrl = new URL(ipaddr);
- URLConnection connection = infoUrl.openConnection();
- HttpURLConnection httpConnection = (HttpURLConnection) connection;
- int responseCode = httpConnection.getResponseCode();
- if (responseCode == HttpURLConnection.HTTP_OK) {
- inStream = httpConnection.getInputStream();
- BufferedReader reader = new BufferedReader(
- new InputStreamReader(inStream, "utf-8"));
- StringBuilder strber = new StringBuilder();
- String line = null;
- while ((line = reader.readLine()) != null)
- strber.append(line + "\n");
- inStream.close();
- return strber.toString();
- }
- } catch (MalformedURLException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- } catch (IOException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- return "";
- }
- // 获取手机MAC地址
- private String getMacAddress() {
- String result = "";
- WifiManager wifiManager = (WifiManager) getSystemService(Context.WIFI_SERVICE);
- WifiInfo wifiInfo = wifiManager.getConnectionInfo();
- result = wifiInfo.getMacAddress();
- // Log.i(TAG, "macAdd:" + result);
- return result;
- }
- // 获取手机屏幕高度
- private String getWeithAndHeight() {
- // 这种方式在service中无法使用,
- DisplayMetrics dm = new DisplayMetrics();
- getWindowManager().getDefaultDisplay().getMetrics(dm);
- int width = dm.widthPixels; // 宽
- int height = dm.heightPixels; // 高
- float density = dm.density; // 屏幕密度(0.75 / 1.0 / 1.5)
- int densityDpi = dm.densityDpi; // 屏幕密度DPI(120 / 160 / 240)
- // 在service中也能得到高和宽
- WindowManager mWindowManager = (WindowManager) getSystemService(Context.WINDOW_SERVICE);
- width = mWindowManager.getDefaultDisplay().getWidth();
- height = mWindowManager.getDefaultDisplay().getHeight();
- // 居中显示Toast
- Toast msg = Toast.makeText(this, "宽=" + width + " 高=" + height,
- Toast.LENGTH_LONG);
- msg.setGravity(Gravity.CENTER, msg.getXOffset() / 2,
- msg.getYOffset() / 2);
- msg.show();
- return "(像素)宽:" + width + "\n" + "(像素)高:" + height + "\n"
- + "屏幕密度(0.75 / 1.0 / 1.5):" + density + "\n"
- + "屏幕密度DPI(120 / 160 / 240):" + densityDpi + "\n";
- /*
- * 下面的代码即可获取屏幕的尺寸。 在一个Activity的onCreate方法中,写入如下代码:
- DisplayMetrics metric = new DisplayMetrics();
- * getWindowManager().getDefaultDisplay().getMetrics(metric);
- * int width = metric.widthPixels; // 屏幕宽度(像素)
- * int height = metric.heightPixels; // 屏幕高度(像素)
- * float density = metric.density; // 屏幕密度(0.75 / 1.0 / 1.5)
- * int densityDpi = metric.densityDpi; // 屏幕密度DPI(120 / 160 / 240)
- *
- * 但是,需要注意的是,在一个低密度的小屏手机上,仅靠上面的代码是不能获取正确的尺寸的。
- * 比如说,一部240x320像素的低密度手机,如果运行上述代码,获取到的屏幕尺寸是320x427。
- * 因此,研究之后发现,若没有设定多分辨率支持的话
- * ,Android系统会将240x320的低密度(120)尺寸转换为中等密度(160)对应的尺寸,
- * 这样的话就大大影响了程序的编码。所以,需要在工程的AndroidManifest
- * .xml文件中,加入supports-screens节点,具体的内容如下: <supports-screens
- * android:smallScreens="true" android:normalScreens="true"
- * android:largeScreens="true" android:resizeable="true"
- * android:anyDensity="true" />
- * 这样的话,当前的Android程序就支持了多种分辨率,那么就可以得到正确的物理尺寸了。
- */
- }
- // 获取手机经纬度
- public void getLocation() {
- // 1. 创建一个 LocationManager对象。
- LocationManager locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
- // 2. 创建一个 LocationListener对象。
- LocationListener myGPSListener = new LocationListener() {
- // 一旦Location发生改变就会调用这个方法
- public void onLocationChanged(Location location) {
- double latitude = location.getLatitude();
- double longitude = location.getLongitude();
- }
- public void onStatusChanged(String provider, int status,
- Bundle extras) {
- }
- public void onProviderEnabled(String provider) {
- }
- public void onProviderDisabled(String provider) {
- }
- };
- // 3.向LocationManager 注册一个LocationListener。
- Criteria criteria = new Criteria();
- criteria.setAccuracy(Criteria.ACCURACY_COARSE);
- criteria.setAltitudeRequired(false);
- criteria.setCostAllowed(true);
- criteria.setPowerRequirement(Criteria.POWER_LOW);
- String provider = locationManager.getBestProvider(criteria, true); // 根据Criteria
- // 的设置获取一个最佳的Provider
- locationManager
- .requestLocationUpdates(provider, 5000, 0, myGPSListener);
- // 4.移除LocationManager 注册的 LocationListener。
- locationManager.removeUpdates(myGPSListener);
- }
- // 当前网络是否连接
- public boolean isNetConnecting() {
- ConnectivityManager connectivityManager = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
- NetworkInfo networkInfo = connectivityManager.getActiveNetworkInfo();
- if (networkInfo == null || !networkInfo.isConnected()) {
- // info.setConnected(false);
- return false;
- } else {
- // info.setConnected(true);
- return true;
- }
- }
- // 获取信号强度
- public void getPhoneState() {
- // 1. 创建telephonyManager 对象。
- TelephonyManager telephonyManager = (TelephonyManager) /* context. */getSystemService(Context.TELEPHONY_SERVICE);
- // 2. 创建PhoneStateListener 对象
- PhoneStateListener MyPhoneListener = new PhoneStateListener() {
- @Override
- public void onCellLocationChanged(CellLocation location) {
- if (location instanceof GsmCellLocation) {// gsm网络
- int CID = ((GsmCellLocation) location).getCid();
- } else if (location instanceof CdmaCellLocation) {// 其他CDMA等网络
- int ID = ((CdmaCellLocation) location).getBaseStationId();
- }
- }
- @Override
- public void onServiceStateChanged(ServiceState serviceState) {
- super.onServiceStateChanged(serviceState);
- }
- @Override
- public void onSignalStrengthsChanged(SignalStrength signalStrength) {
- int asu = signalStrength.getGsmSignalStrength();
- int dbm = -113 + 2 * asu; // 信号强度
- super.onSignalStrengthsChanged(signalStrength);
- }
- };
- // 3. 监听信号改变
- telephonyManager.listen(MyPhoneListener,
- PhoneStateListener.LISTEN_SIGNAL_STRENGTHS);
- /*
- * 可能需要的权限 <uses-permission
- * android:name="android.permission.WAKE_LOCK"></uses-permission>
- * <uses-permission
- * android:name="android.permission.ACCESS_COARSE_LOCATION"/>
- * <uses-permission
- * android:name="android.permission.ACCESS_FINE_LOCATION"/>
- * <uses-permission android:name="android.permission.READ_PHONE_STATE"
- * /> <uses-permission
- * android:name="android.permission.ACCESS_NETWORK_STATE" />
- */
- }
- // 获取手机可用内存和总内存
- private String getSystemMemory() {
- /*
- * 在android开发中,有时候我们想获取手机的一些硬件信息,比如android手机的总内存和可用内存大小。这个该如何实现呢?
- * 通过读取文件"/proc/meminfo" 的信息能够获取手机Memory的总量,而通过ActivityManager.getMemoryInfo
- * (ActivityManager.MemoryInfo)方法可以获取当前的可用Memory量。
- * "/proc/meminfo"文件记录了android手机的一些内存信息
- * ,在命令行窗口里输入"adb shell",进入shell环境,输入
- * "cat /proc/meminfo"即可在命令行里显示meminfo文件的内容,具体如下所示。
- *
- * C:\Users\Figo>adb shell # cat /proc/meminfo cat /proc/meminfo
- * MemTotal: 94096 kB
- * MemFree: 1684 kB Buffers: 16 kB Cached: 27160 kB
- * SwapCached: 0 kB Active: 35392 kB Inactive: 44180 kB
- * Active(anon): 26540 kB Inactive(anon): 28244 kB Active(file): 8852 kB
- * Inactive(file): 15936 kB Unevictable: 280 kB Mlocked: 0 kB * SwapTotal: 0 kB SwapFree: 0 kB Dirty: 0 kB Writeback: 0 kB AnonPages: 52688 kB
- * Mapped: 17960 kB Slab: 3816 kB SReclaimable: 936 kB SUnreclaim: 2880
- * kB PageTables: 5260 kB NFS_Unstable: 0 kB Bounce: 0 kB
- * WritebackTmp: 0 kB
- * CommitLimit: 47048 kB
- * Committed_AS: 1483784 kB
- * VmallocTotal: 876544 kB
- * VmallocUsed: 15456 kB
- * VmallocChunk: 829444 kB #
- *
- * 下面先对"/proc/meminfo"文件里列出的字段进行粗略解释: MemTotal: 所有可用RAM大小。 MemFree:
- * LowFree与HighFree的总和,被系统留着未使用的内存。 Buffers: 用来给文件做缓冲大小。 Cached:
- * 被高速缓冲存储器(cache memory)用的内存的大小(等于diskcache minus SwapCache)。
- * SwapCached:被高速缓冲存储器(cache
- * memory)用的交换空间的大小。已经被交换出来的内存,仍然被存放在swapfile中,
- * 用来在需要的时候很快的被替换而不需要再次打开I/O端口。 Active:
- * 在活跃使用中的缓冲或高速缓冲存储器页面文件的大小,除非非常必要,否则不会被移作他用。 Inactive:
- * 在不经常使用中的缓冲或高速缓冲存储器页面文件的大小,可能被用于其他途径。 SwapTotal: 交换空间的总大小。 SwapFree:
- * 未被使用交换空间的大小。 Dirty: 等待被写回到磁盘的内存大小。 Writeback: 正在被写回到磁盘的内存大小。
- * AnonPages:未映射页的内存大小。 Mapped: 设备和文件等映射的大小。 Slab:
- * 内核数据结构缓存的大小,可以减少申请和释放内存带来的消耗。 SReclaimable:可收回Slab的大小。
- * SUnreclaim:不可收回Slab的大小(SUnreclaim+SReclaimable=Slab)。
- * PageTables:管理内存分页页面的索引表的大小。 NFS_Unstable:不稳定页表的大小。
- * 要获取android手机总内存大小,只需读取"/proc/meminfo"文件的第1行,并进行简单的字符串处理即可。
- */
- String availMemory = getAvailMemory();
- String totalMemory = getTotalMemory();
- return "可用内存=" + availMemory + "\n" + "总内存=" + totalMemory;
- }// 手机的内存信息主要在/proc/meminfo文件中,其中第一行是总内存,而剩余内存可通过ActivityManager.MemoryInfo得到。
- private String getAvailMemory() {// 获取android当前可用内存大小
- ActivityManager am = (ActivityManager) getSystemService(Context.ACTIVITY_SERVICE);
- MemoryInfo mi = new MemoryInfo();
- am.getMemoryInfo(mi);
- // mi.availMem; 当前系统的可用内存
- return Formatter.formatFileSize(getBaseContext(), mi.availMem);// 将获取的内存大小规格化
- }
- private String getTotalMemory() {
- String str1 = "/proc/meminfo";// 系统内存信息文件
- String str2;
- String[] arrayOfString;
- long initial_memory = 0;
- try {
- FileReader localFileReader = new FileReader(str1);
- BufferedReader localBufferedReader = new BufferedReader(
- localFileReader, 8192);
- str2 = localBufferedReader.readLine();// 读取meminfo第一行,系统总内存大小
- arrayOfString = str2.split("\\s+");
- for (String num : arrayOfString) {
- Log.i(str2, num + "\t");
- }
- initial_memory = Integer.valueOf(arrayOfString[1]).intValue() * 1024;// 获得系统总内存,单位是KB,乘以1024转换为Byte
- localBufferedReader.close();
- } catch (IOException e) {
- }
- return Formatter.formatFileSize(getBaseContext(), initial_memory);// Byte转换为KB或者MB,内存大小规格化
- }
- // 获取手机CPU信息
- private String getCpuInfo() {
- String str1 = "/proc/cpuinfo";
- String str2 = "";
- String[] cpuInfo = { "", "" }; // 1-cpu型号 //2-cpu频率
- String[] arrayOfString;
- try {
- FileReader fr = new FileReader(str1);
- BufferedReader localBufferedReader = new BufferedReader(fr, 8192);
- str2 = localBufferedReader.readLine();
- arrayOfString = str2.split("\\s+");
- for (int i = 2; i < arrayOfString.length; i++) {
- cpuInfo[0] = cpuInfo[0] + arrayOfString[i] + " ";
- }
- str2 = localBufferedReader.readLine();
- arrayOfString = str2.split("\\s+");
- cpuInfo[1] += arrayOfString[2];
- localBufferedReader.close();
- } catch (IOException e) {
- }
- // Log.i(TAG, "cpuinfo:" + cpuInfo[0] + " " + cpuInfo[1]);
- return "1-cpu型号:" + cpuInfo[0] + "2-cpu频率:" + cpuInfo[1];
- }// 和内存信息同理,cpu信息可通过读取/proc/cpuinfo文件来得到,其中第一行为cpu型号,第二行为cpu频率。
- /*
- * 一、Android 获取手机中已安装apk文件信息(PackageInfo、ResolveInfo)(应用图片、应用名、包名等)
- * 1、通过PackageManager可获取手机端已安装的apk文件的信息,具体代码如下: PackageManager
- * packageManager = this.getPackageManager(); List<PackageInfo>
- * packageInfoList = packageManager.getInstalledPackages(0);
- * 通过上述方法,可得到手机中安装的所有应用程序,包括手动安装的apk包的信息、、系统预装的应用软件的信息,要区分这两类软件可使用以下方法:
- * (a)从packageInfoList获取的packageInfo
- * ,再通过packageInfo.applicationInfo获取applicationInfo。
- * (b)判断(applicationInfo.flags &
- * ApplicationInfo.FLAG_SYSTEM)的值,该值大于0时,表示获取的应用为系统预装的应用,反之则为手动安装的应用。
- * (1)获取应用的代码: public static List<PackageInfo> getAllApps(Context context) {
- * List<PackageInfo> apps = new ArrayList<PackageInfo>(); PackageManager
- * pManager = context.getPackageManager(); //获取手机内所有应用 List<PackageInfo>
- * paklist = pManager.getInstalledPackages(0); for (int i = 0; i <
- * paklist.size(); i++) { PackageInfo pak = (PackageInfo) paklist.get(i);
- * //判断是否为非系统预装的应用程序 if ((pak.applicationInfo.flags &
- * pak.applicationInfo.FLAG_SYSTEM) <= 0) { apps.add(pak); } } return apps;
- * } (2)、获取图片、应用名、包名: PackageManager pManager =
- * MessageSendActivity.this.getPackageManager(); List<PackageInfo> appList =
- * Utils.getAllApps(MessageSendActivity.this); for(int
- * i=0;i<appList.size();i++) { PackageInfo pinfo = appList.get(i); shareItem
- * = new ShareItemInfo();
- * shareItem.setIcon(pManager.getApplicationIcon(pinfo.applicationInfo));
- * shareItem
- * .setLabel(pManager.getApplicationLabel(pinfo.applicationInfo).toString
- * ()); shareItem.setPackageName(pinfo.applicationInfo.packageName); }
- * 其中ShareItemInfo 类自己写的,各位可以忽略 (3)获取支持分享的应用的代码: public static
- * List<ResolveInfo> getShareApps(Context context){ List<ResolveInfo> mApps
- * = new ArrayList<ResolveInfo>(); Intent intent=new
- * Intent(Intent.ACTION_SEND,null);
- * intent.addCategory(Intent.CATEGORY_DEFAULT);
- * intent.setType("text/plain"); PackageManager pManager =
- * context.getPackageManager(); mApps =
- * pManager.queryIntentActivities(intent
- * ,PackageManager.COMPONENT_ENABLED_STATE_DEFAULT); return mApps; }
- * 由于该方法,返回的并不是PackageInfo 对象。而是ResolveInfo。因此获取图片、应用名、包名的方法不一样,如下:
- * PackageManager pManager = MessageSendActivity.this.getPackageManager();
- * List<ResolveInfo> resolveList =
- * Utils.getShareApps(MessageSendActivity.this); for(int
- * i=0;i<resolveList.size();i++) { ResolveInfo resolve = resolveList.get(i);
- * ShareItemInfo shareItem = new ShareItemInfo(); //set Icon
- * shareItem.setIcon(resolve.loadIcon(pManager)); //set Application Name
- * shareItem.setLabel(resolve.loadLabel(pManager).toString()); //set Package
- * Name shareItem.setPackageName(resolve.activityInfo.packageName); } 总结: 通过
- * PackageInfo 获取具体信息方法: 包名获取方法:packageInfo.packageName
- * icon获取获取方法:packageManager.getApplicationIcon(applicationInfo)
- * 应用名称获取方法:packageManager.getApplicationLabel(applicationInfo)
- * 使用权限获取方法:packageManager
- * .getPackageInfo(packageName,PackageManager.GET_PERMISSIONS)
- * .requestedPermissions 通过 ResolveInfo 获取具体信息方法:
- * 包名获取方法:resolve.activityInfo.packageName
- * icon获取获取方法:resolve.loadIcon(packageManager)
- * 应用名称获取方法:resolve.loadLabel(packageManager).toString()
- */
- ublic String getSimCardInfo() {
- // 在manifest.xml文件中要添加
- // <uses-permission android:name="android.permission.READ_PHONE_STATE"/>
- /*
- * TelephonyManager类主要提供了一系列用于访问与手机通讯相关的状态和信息的get方法。其中包括手机SIM的状态和信息
- * 、电信网络的状态及手机用户的信息。
- * 在应用程序中可以使用这些get方法获取相关数据。TelephonyManager类的对象可以通过Context
- * .getSystemService(Context.TELEPHONY_SERVICE)
- * 方法来获得,需要注意的是有些通讯信息的获取对应用程序的权限有一定的限制
- * ,在开发的时候需要为其添加相应的权限。以下列出TelephonyManager类所有方法及说明:
- * TelephonyManager提供设备上获取通讯服务信息的入口。 应用程序可以使用这个类方法确定的电信服务商和国家
- * 以及某些类型的用户访问信息。 应用程序也可以注册一个监听器到电话收状态的变化。不需要直接实例化这个类
- * 使用Context.getSystemService (Context.TELEPHONY_SERVICE)来获取这个类的实例。
- */
- // 解释:
- // IMSI是国际移动用户识别码的简称(International Mobile Subscriber Identity)
- // IMSI共有15位,其结构如下:
- // MCC+MNC+MIN
- // MCC:Mobile Country Code,移动国家码,共3位,中国为460;
- // MNC:Mobile NetworkCode,移动网络码,共2位
- // 在中国,移动的代码为电00和02,联通的代码为01,电信的代码为03
- // 合起来就是(也是Android手机中APN配置文件中的代码):
- // 中国移动:46000 46002
- // 中国联通:46001
- // 中国电信:46003
- // 举例,一个典型的IMSI号码为460030912121001
- // IMEI是International Mobile Equipment Identity (国际移动设备标识)的简称
- // IMEI由15位数字组成的”电子串号”,它与每台手机一一对应,而且该码是全世界唯一的
- // 其组成为:
- // 1. 前6位数(TAC)是”型号核准号码”,一般代表机型
- // 2. 接着的2位数(FAC)是”最后装配号”,一般代表产地
- // 3. 之后的6位数(SNR)是”串号”,一般代表生产顺序号
- // 4. 最后1位数(SP)通常是”0″,为检验码,目前暂备用
- TelephonyManager tm = (TelephonyManager) this
- .getSystemService(TELEPHONY_SERVICE);
- /*
- * 电话状态: 1.tm.CALL_STATE_IDLE=0 无活动,无任何状态时 2.tm.CALL_STATE_RINGING=1
- * 响铃,电话进来时 3.tm.CALL_STATE_OFFHOOK=2 摘机
- */
- tm.getCallState();// int
- /*
- * 电话方位:
- */
- // 返回当前移动终端的位置
- CellLocation location = tm.getCellLocation();
- // 请求位置更新,如果更新将产生广播,接收对象为注册LISTEN_CELL_LOCATION的对象,需要的permission名称为
- // ACCESS_COARSE_LOCATION。
- location.requestLocationUpdate();
- /**
- * 获取数据活动状态
- *
- * DATA_ACTIVITY_IN 数据连接状态:活动,正在接受数据 DATA_ACTIVITY_OUT 数据连接状态:活动,正在发送数据
- * DATA_ACTIVITY_INOUT 数据连接状态:活动,正在接受和发送数据 DATA_ACTIVITY_NONE
- * 数据连接状态:活动,但无数据发送和接受
- */
- tm.getDataActivity();
- /**
- * 获取数据连接状态
- *
- * DATA_CONNECTED 数据连接状态:已连接 DATA_CONNECTING 数据连接状态:正在连接
- * DATA_DISCONNECTED 数据连接状态:断开 DATA_SUSPENDED 数据连接状态:暂停
- */
- tm.getDataState();
- /**
- * 返回当前移动终端的唯一标识,设备ID
- *
- * 如果是GSM网络,返回IMEI;如果是CDMA网络,返回MEID Return null if device ID is not
- * available.
- */
- String Imei = tm.getDeviceId();// String
- /*
- * 返回移动终端的软件版本,例如:GSM手机的IMEI/SV码。 设备的软件版本号: 例如:the IMEI/SV(software
- * version) for GSM phones. Return null if the software version is not
- * available.
- */
- tm.getDeviceSoftwareVersion();// String
- /*
- * 手机号: GSM手机的 MSISDN. Return null if it is unavailable.
- */
- String phoneNum = tm.getLine1Number();// String
- /*
- * 获取ISO标准的国家码,即国际长途区号。 注意:仅当用户已在网络注册后有效。 在CDMA网络中结果也许不可靠。
- */
- tm.getNetworkCountryIso();// String
- /*
- * MCC+MNC(mobile country code + mobile network code) 注意:仅当用户已在网络注册时有效。
- * 在CDMA网络中结果也许不可靠。
- */
- tm.getNetworkOperator();// String
- /*
- * 按照字母次序的current registered operator(当前已注册的用户)的名字 注意:仅当用户已在网络注册时有效。
- * 在CDMA网络中结果也许不可靠。
- */
- tm.getNetworkOperatorName();// String
- /*
- * 当前使用的网络类型: 例如: NETWORK_TYPE_UNKNOWN 网络类型未知 0 NETWORK_TYPE_GPRS GPRS网络
- * 1 NETWORK_TYPE_EDGE EDGE网络 2 NETWORK_TYPE_UMTS UMTS网络 3
- * NETWORK_TYPE_HSDPA HSDPA网络 8 NETWORK_TYPE_HSUPA HSUPA网络 9
- * NETWORK_TYPE_HSPA HSPA网络 10 NETWORK_TYPE_CDMA CDMA网络,IS95A 或 IS95B. 4
- * NETWORK_TYPE_EVDO_0 EVDO网络, revision 0. 5 NETWORK_TYPE_EVDO_A EVDO网络,
- * revision A. 6 NETWORK_TYPE_1xRTT 1xRTT网络 7
- */
- tm.getNetworkType();// int
- /*
- * 手机类型: 例如: PHONE_TYPE_NONE 无信号 PHONE_TYPE_GSM GSM信号 PHONE_TYPE_CDMA
- * CDMA信号
- */
- tm.getPhoneType();// int
- /*
- * Returns the ISO country code equivalent for the SIM provider‘s
- * country code. 获取ISO国家码,相当于提供SIM卡的国家码。
- */
- tm.getSimCountryIso();// String
- /*
- * Returns the MCC+MNC (mobile country code + mobile network code) of
- * the provider of the SIM. 5 or 6 decimal digits.
- * 获取SIM卡提供的移动国家码和移动网络码.5或6位的十进制数字. SIM卡的状态必须是
- * SIM_STATE_READY(使用getSimState()判断).
- */
- tm.getSimOperator();// String
- /*
- * 服务商名称: 例如:中国移动、联通 SIM卡的状态必须是 SIM_STATE_READY(使用getSimState()判断).
- */
- tm.getSimOperatorName();// String
- /*
- * SIM卡的序列号: 需要权限:READ_PHONE_STATE
- */
- tm.getSimSerialNumber();// String
- /*
- * SIM的状态信息: SIM_STATE_UNKNOWN 未知状态 0 SIM_STATE_ABSENT 没插卡 1
- * SIM_STATE_PIN_REQUIRED 锁定状态,需要用户的PIN码解锁 2 SIM_STATE_PUK_REQUIRED
- * 锁定状态,需要用户的PUK码解锁 3 SIM_STATE_NETWORK_LOCKED 锁定状态,需要网络的PIN码解锁 4
- * SIM_STATE_READY 就绪状态 5
- */
- tm.getSimState();// int
- /*
- * 唯一的用户ID: 例如:IMSI(国际移动用户识别码) for a GSM phone. 需要权限:READ_PHONE_STATE
- */
- tm.getSubscriberId();// String
- /*
- * 取得和语音邮件相关的标签,即为识别符 需要权限:READ_PHONE_STATE
- */
- tm.getVoiceMailAlphaTag();// String
- /*
- * 获取语音邮件号码: 需要权限:READ_PHONE_STATE
- */
- tm.getVoiceMailNumber();// String
- /*
- * ICC卡是否存在
- */
- tm.hasIccCard();// boolean
- /*
- * 是否漫游: (在GSM用途下)
- */
- tm.isNetworkRoaming();//
- String ProvidersName = null;
- // 返回唯一的用户ID;就是这张卡的编号神马的
- String IMSI = tm.getSubscriberId(); // 国际移动用户识别码
- // IMSI号前面3位460是国家,紧接着后面2位00 02是中国移动,01是中国联通,03是中国电信。
- System.out.println(IMSI);
- if (IMSI.startsWith("46000") || IMSI.startsWith("46002")) {
- ProvidersName = "中国移动";
- } else if (IMSI.startsWith("46001")) {
- ProvidersName = "中国联通";
- } else if (IMSI.startsWith("46003")) {
- ProvidersName = "中国电信";
- }
- // 返回当前移动终端附近移动终端的信息
- /*
- * 附近的电话的信息: 类型:List<NeighboringCellInfo>
- * 需要权限:android.Manifest.permission#ACCESS_COARSE_UPDATES
- */
- List<NeighboringCellInfo> infos = tm.getNeighboringCellInfo();
- for (NeighboringCellInfo info : infos) {
- // 获取邻居小区号
- int cid = info.getCid();
- // 获取邻居小区LAC,LAC:
- // 位置区域码。为了确定移动台的位置,每个GSM/PLMN的覆盖区都被划分成许多位置区,LAC则用于标识不同的位置区。
- info.getLac();
- info.getNetworkType();
- info.getPsc();
- // 获取邻居小区信号强度
- info.getRssi();
- }
- return "手机号码:" + phoneNum + "\n" + "服务商:" + ProvidersName+"\n" + "IMEI:" + Imei;
- }
- // 显示信息对话框
- public void showDialog(String title, String info) {
- AlertDialog dialog = new AlertDialog.Builder(this)
- .setTitle(title)
- .setMessage(info)
- .setPositiveButton("close",
- new DialogInterface.OnClickListener() {
- @Override
- public void onClick(DialogInterface dialog,
- int which) {
- dialog.cancel();
- dialog = null;
- }
- }).create();
- dialog.show();
- }
本文出自 “java之路” 博客,请务必保留此出处http://2402766.blog.51cto.com/2392766/1080837
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。