最近研究App拥有root权限,弄了好久关机重启都没有成功,特别郁闷。就换另外一种更简单的方式,一试就成功了。
步骤一:编写Java代码 java部分代码: case R.id. broadcast_reboot : //重启 Log.v( "Reboot" , "Reboot-->broadcast_reboot" ); Intent i = new Intent(Intent. ACTION_REBOOT ); i.putExtra( "nowait" , 1); i.putExtra( "interval" , 1); i.putExtra( "window" , 0); sendBroadcast(i);
break ; case R.id. broadcast_shutdown : //关机 Log.v( "Reboot" , "Reboot-->broadcast_shutdown" ); Intent intent = new Intent(Intent.ACTION_REQUEST_SHUTDOWN); intent.putExtra(Intent.EXTRA_KEY_CONFIRM, false ); intent.setFlags(Intent. FLAG_ACTIVITY_NEW_TASK ); startActivity(intent);
break ; 注:关机可以设置时间设置【定时关机】功能,关机中的Intent.ACTION_REQUEST_SHUTDOWN 及 Intent.EXTRA_KEY_CONFIRM 在IDE中报错,但可以忽略,因为这两个属性不对上层开放,APP在源码中编译就可以直接使用。
步骤二:修改Manifest.xml中属性
< manifest xmlns:android = "http://schemas.android.com/apk/res/android"
……
android:sharedUserId = "android.uid.system"
……
>
< uses-permission android:name = "android.permission.SHUTDOWN" />
……
</ manifest >
注: android:sharedUserId="android.uid.system" 将app提升到系统权限,需要到源码中编译,还有关机权限: android.permission.SHUTDOWN
步骤三:编译APK 将项目拷贝到Android源码中进行编译,我拷贝到【 gingerbread/development/apps/】下,并将项目的bin文件夹给删除,同时最重要的一步在项目下编写mk文件,山寨其它项目的mk文件写如下,不要漏掉 LOCAL_CERTIFICATE := platform
Android.mk:
LOCAL_PATH:= $(call my-dir)
include $(CLEAR_VARS)

LOCAL_MODULE_TAGS := optional

LOCAL_SRC_FILES := $(call all-java-files-under, src)

LOCAL_PACKAGE_NAME :=你的项目名
LOCAL_CERTIFICATE := platform

include $(BUILD_PACKAGE)

步骤四: 通过mm编译生成的apk安装到机器中,就可以操作重启及关机
注:使用相同的方法可以修改系统时间,重点是将应用提升到拥有系统权限,但进过此操作并未获得root权限。
补充:后来使用init.rc启动系统服务的方法也是可行的,之前是因为编写关机 和 重启的sh文件使用了中文符号,使得sh命令有问题
方法二可以参考:http://my.unix-center.net/~Simon_fu/?p=951

PS:想了解进一步定制开机重启功能请点此为Android系统定制重启功能
进一步测试: 通过编译后到apk不能安装,主要是因为系统权限的问题。(Failure [INSTALL_FAILED_SHARED_USER_INCOMPATIBLE]),需用在相同源码固件的系统才能使用系统签名的应用。

首先AndroidManifest.xml中加入android:sharedUserId="android.uid.system"这个属性。通过Shared User id,拥有同一个User id的多个APK可以配置成运行在同一个进程中。那么把程序的UID配成android.uid.system,也就是要让程序运行在系统进程中,这样就有权限来修改系统时间了。 

只是加入UID还不够,如果这时候安装APK的话发现无法安装,提示签名不符,原因是程序想要运行在系统进程中还要有目标系统的platformkey,就是上面第二个方法提到的platform.pk8和platform.x509.pem两个文件。用这两个key签名后apk才真正可以放入系统进程中。第一个方法中加入LOCAL_CERTIFICATE := platform其实就是用这两个key来签名。  这也有一个问题,就是这样生成的程序只有在原始的Android系统或者是自己编译的系统中才可以用,因为这样的系统才可以拿到 platform.pk8和platform.x509.pem两个文件。要是别家公司做的Android上连安装都安装不了。试试原始的Android 中的key来签名,程序在模拟器上运行OK

见链接:http://bbs.gfan.com/android-85440-1-1.html

更多相关文章

  1. ubuntu10 集成android创建工程出错解决
  2. Android(安卓)获取系统或SDCARD剩余空间信息
  3. Android(安卓)错误 The method onClick(View) of type new View.
  4. Android中获取应用程序(包)的信息(launcher获取系统应用)
  5. 漫谈android系统(1)解析android编译
  6. android使用NDK编译curl库
  7. Android开发1——查找所需要出示权限的内容
  8. 【Android】Error: Expected resource of type styleable [Resou
  9. Android(安卓)Studio编译问题-Error:Could not find org.jetbrai

随机推荐

  1. 使用 Android(安卓)实现联网
  2. 【android】AsyncTask完全剖析(二)
  3. Android 仿微信Activity左右切换 【全局
  4. 【Android开发学习02】Android应用程序的
  5. 使用android studio 查看 android 的源代
  6. Android Studio和Eclipse快捷键对比,及快
  7. android 字符串、颜色和尺寸
  8. Android中添加思源字体/NotoSansCJK/Sour
  9. Android之Service案例-电话窃听
  10. Flutter(环境搭建-Android视角)