最近在将 HevSocks5Client 移植到 Android 上了,在经过增加 signalfd 和 timerfd 相关的系统调用支持后,就可以直接使用 NDK 编译出 executable 了。直接的 native exectuable 在 Android 系统总还是不太方便用哦。还是做成一个 apk 吧,暂定只写一个 service 并开机自动启用,无 activity 的。
Java 中调用 native 程序我选择使用 JNI 方式,直接在 JNI_OnLoad 方法中调用 pthread_create 创建个线程跑原来的 main 就行啦。
... #if defined(ANDROID) #include <jni.h> #include <pthread.h> #endif int main (int argc, char *argv[]) { ... } #if defined(ANDROID) static void * thread_handler (void *data) { main (0, NULL); return NULL; } jint JNI_OnLoad (JavaVM *vm, void *reserved) { pthread_t thread; pthread_create (&thread, NULL, thread_handler, NULL); return JNI_VERSION_1_4; } #endif
Android 服务
服务主要是加载 JNI 接口的 hev-socks5-client 库,使服务跑起来。
package hev.socks5; import android.app.Service; import android.content.Intent; import android.os.IBinder; import android.util.Log; public class MainService extends Service { static { System.loadLibrary("hev-socks5-client"); } public IBinder onBind(Intent intent) { return null; } }
BroadcastReceiver
ServiceReceiver 的功能就是监听系统上的 BOOT_COMPLETED 事件,用于实现自动启动服务。
package hev.socks5; import android.content.BroadcastReceiver; import android.content.Context; import android.content.Intent; public class ServiceReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { if (intent.getAction().equals(Intent.ACTION_BOOT_COMPLETED)) { Intent i = new Intent(context, MainService.class); context.startService(i); } } }
AndroidManifest.xml
最后,要在 Manifest 中注册 Service 和 Receiver,增加上访问 Internet 和 Boot completed 的权限。
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="hev.socks5" android:versionCode="1" android:versionName="1.0"> <application android:label="@string/app_name" > <service android:name=".MainService"> <intent-filter> <action android:name="hev.socks5.MainService" /> </intent-filter> </service> <receiver android:enabled="true" android:name=".ServiceReceiver"> <intent-filter> <action android:name="android.intent.action.BOOT_COMPLETED" /> </intent-filter> </receiver> </application> <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" /> </manifest>
Tips
此方法仅在 Android 2.3.3 及之前版本有效,之后版本如果此应用在安装后从没运行过,Broadcast Receiver 将接收不到 boot completed 的 action,解决方法是使用命令手动启动一下 service。
am startservice hev.socks5/.MainService
本文向大家介绍C语言实现程序开机自启动,包括了C语言实现程序开机自启动的使用技巧和注意事项,需要的朋友参考一下 程序比较简单,用到了C语言获得自身路径和系统路径,修改注册表项等,某些函数不理解可以查看MSDN
本文向大家介绍C#实现开机自动启动设置代码分享,包括了C#实现开机自动启动设置代码分享的使用技巧和注意事项,需要的朋友参考一下
本文向大家介绍linux 开机自启动redis服务的方法,包括了linux 开机自启动redis服务的方法的使用技巧和注意事项,需要的朋友参考一下 1.先输入 把上述配置复制进去,保存退出 2.设置开机自启动 systemctl enable redis 3.使用命令 总结 以上所述是小编给大家介绍的linux 开机自启动redis服务的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编
问题内容: 从我在Stack Exchange和其他地方看到的所有内容中,我已经正确设置了所有内容,可以在启动Android OS时启动IntentService。不幸的是,它没有在启动时启动,并且我没有收到任何错误。也许专家可以帮忙… 表现: 用于启动的BroadcastReceiver: 更新:我尝试了下面的几乎所有建议,并;在处理程序中添加了日志记录,但从未记录过任何内容。因此,它甚至还没有
我正试图将opentelemetry集成到我与jaeger的spring boot应用程序中。我正在本地计算机上运行jaeger(用二进制而不是docker启动),并用以下命令启动spring boot应用程序:
问题内容: 我在启动时无法启动服务。 我有一个广播接收器,只要设备启动(不是),就应该调用它,它会启动我的服务。不幸的是,该服务尚未启动! 我查看了此页面,阅读了所有答案,并按照每个步骤进行了操作……但是它仍然无法正常工作。每当手机重新启动/开机时,我都想启动我的服务。 但是我的服务仍然无法启动。这是我的清单: 在过去的三天中,我一直对此保持执着, 非常感谢您的帮助。为什么我的服务无法在启动时启动