在Android中,为了确保应用程序保持私密性,应使用更精确和有选择性的方法来控制应用程序的可见性。例如,可以使用这样一种方法,在清单文件中声明可见性:android:exported="true"或者android:exported="false",以标识哪些组件可以被外部应用程序访问。
代码示例:
//在AndroidManifest.xml文件中,将允许的组件(例如Activity或Service)标识为exported或non-exported:
//在这个例子中,MyActivity被标记为非导出的,不能被外部应用程序访问。而MyService被标记为可导出的,可以被外部应用程序访问。
//这里还有一些其他的方法可以用来控制Android应用程序的可见性,例如在代码中检查是否有调用者和权限等。
//例如,下面的代码片段使用PackageManager检查调用者是否有权限访问MyService:
PackageManager pm = getPackageManager(); ComponentName serviceName = new ComponentName(this, MyService.class); int result = pm.checkPermission(Manifest.permission.ACCESS_FINE_LOCATION, serviceName.getPackageName()); if (result == PackageManager.PERMISSION_GRANTED) { //我们有访问权限,可以启动服务了 Intent intent = new Intent(this, MyService.class); startService(intent); } else { //我们没有权限,需要请求授权 ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.ACCESS_FINE_LOCATION}, 0); }