android之获取手机信息 发表于 2013-07-18 | 分类于 Android | 阅读次数: android获取手机信息(号码,内存,CPU,分辨率,MAC,IP,SD卡,IMEI,经纬度,信号强度等等) 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728package com.android.xiaomolong.example.apkdemo; import java.io.BufferedReader;import java.io.File;import java.io.FileReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;import java.net.HttpURLConnection;import java.net.InetAddress;import java.net.MalformedURLException;import java.net.NetworkInterface;import java.net.SocketException;import java.net.URL;import java.net.URLConnection;import java.util.Enumeration;import java.util.List;import android.app.Activity;import android.app.ActivityManager;import android.app.ActivityManager.MemoryInfo;import android.app.AlertDialog;import android.content.Context;import android.content.DialogInterface;import android.location.Criteria;import android.location.Location;import android.location.LocationListener;import android.location.LocationManager;import android.net.ConnectivityManager;import android.net.NetworkInfo;import android.net.wifi.WifiInfo;import android.net.wifi.WifiManager;import android.os.Bundle;import android.os.Environment;import android.os.StatFs;import android.telephony.CellLocation;import android.telephony.NeighboringCellInfo;import android.telephony.PhoneStateListener;import android.telephony.ServiceState;import android.telephony.SignalStrength;import android.telephony.TelephonyManager;import android.telephony.cdma.CdmaCellLocation;import android.telephony.gsm.GsmCellLocation;import android.text.format.Formatter;import android.util.DisplayMetrics;import android.util.Log;import android.view.Gravity;import android.view.WindowManager;import android.widget.Toast;/** * * @author 小尛龙 * */public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Log.d("wxl", getSystemMemory()); } // 获取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() */ public 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(); }} 联系作者 我的微信公众号:吴小龙同学,欢迎关注交流,公号回复关键字「1024」有惊喜哦。