Android sqlite3 编译及安装

  1. 编译 sqlite3
    去官网下载 sqlite-autoconf-xxxxxxx.tar.gz 并解压
    确保电脑配置了 ANDROID_HOME 环境变量,修改脚本中对应的 ndk 版本号
    如果是32位架构,HOST 改为 armv7a,API 修改为对应手机的 Android 系统版本
    脚本如下:
bash 复制代码
#!/bin/bash

export TOOLCHAIN=$ANDROID_HOME/ndk/29.0.14206865/toolchains/llvm/prebuilt/darwin-x86_64
export HOST=aarch64-linux-android
export API=29
export CC=$TOOLCHAIN/bin/$HOST$API-clang
export CXX=$TOOLCHAIN/bin/$HOST$API-clang++
export AR=$TOOLCHAIN/bin/$HOST-ar
export AS=$TOOLCHAIN/bin/$HOST-as
export LD=$TOOLCHAIN/bin/$HOST-ld
export RANLIB=$TOOLCHAIN/bin/$HOST-ranlib
export STRIP=$TOOLCHAIN/bin/$HOST-strip
export CFLAGS="-mthumb -fpic -ffunction-sections -funwind-tables -fstack-protector-all -fno-strict-aliasing"
export CXXFLAGS="$CFLAGS -frtti -fexceptions"

./configure --prefix=`pwd`/build/sqlite3/ \
            --host=$HOST \
            --enable-shared \
            --disable-static
            
if [ $? -eq 0 ]; then
    make clean
    make -j16
    make install
fi
  1. push 到 /bin
bash 复制代码
adb -s e102dcb0 push `pwd`/build/sqlite3/bin/sqlite3 /sdcard
adb -s e102dcb0 shell << EOF
  su

  # 0. 移动sqlite3
  mv /sdcard/sqlite3 /data/local/tmp
	
	# 1. 定义模块目录变量
	MODDIR=/data/adb/modules/custom_path
	
	# 2. 创建目录
	mkdir -p $MODDIR/system/etc
	
	# 3. 写入 mkshrc 文件
	cat > $MODDIR/system/etc/mkshrc << 'EOF'
	# 为所有 shell(adb shell、终端模拟器、su 后的 shell)添加自定义 PATH
	export PATH=$PATH:/data/local/tmp
	EOF
	
	# 4. 写入模块属性文件
	cat > $MODDIR/module.prop << 'EOF'
	id=custom_path
	name=Custom PATH
	version=1
	versionCode=1
	author=equuleus
	description=Add /data/local/tmp to PATH for all shells
	EOF
	
	# 5. 设置权限
	chmod -R 755 $MODDIR
	chmod 644 $MODDIR/system/etc/mkshrc
	
	# 6. 验证文件已创建
	ls -l $MODDIR
	ls -l $MODDIR/system/etc/

  # 7.重启手机
  reboot

EOF

cd 到源码目录执行上述脚本会生成 sqlite3 可执行文件,如果你的手机已经是完全 root 过的,则直接 push 到 /system/xbin/ 即可。

但是我的手机是借助 magisk 来开启 root 权限的,是没有 system 分区的写权限的,这里我们先将 sqlite3 push 到 /sdcard 目录下,然后需要编写一个 magisk 模块 custom_path 来开启读写权限。

安装好 custom_path 模块后,重启执行 sqlite3 --version 。

bash 复制代码
(base) longwei@Mac-Pro ~ % adb -s e102dcb0 shell
$ su
# echo $PATH
/sbin:/system/sbin:/product/bin:/apex/com.android.runtime/bin:/system/bin:/system/xbin:/odm/bin:/vendor/bin:/vendor/xbin:/data/local/tmp:/data/local/tmp
# sqlite3 --version
3.51.3 2026-03-13 10:38:09 737ae4a34738ffa0c3ff7f9bb18df914dd1cad163f28fd6b6e114a344fe6d618 (64-bit)
相关推荐
geBR OTTE14 小时前
SpringBoot中整合ONLYOFFICE在线编辑
java·spring boot·后端
Porunarufu14 小时前
博客系统UI自动化测试报告
java
哑巴湖小水怪15 小时前
Android的架构是四层还是五层
android·架构
Aurorar0rua15 小时前
CS50 x 2024 Notes C - 05
java·c语言·数据结构
Cosmoshhhyyy16 小时前
《Effective Java》解读第49条:检查参数的有效性
java·开发语言
布谷歌16 小时前
常见的OOM错误 ( OutOfMemoryError全类型详解)
java·开发语言
eLIN TECE16 小时前
springboot和springframework版本依赖关系
java·spring boot·后端
2501_9160088917 小时前
深入解析iOS应用启动性能优化策略与实践
android·ios·性能优化·小程序·uni-app·cocoa·iphone
老神在在00117 小时前
Spring Bean 的六种作用域详解
java·后端·spring
仙草不加料17 小时前
互联网大厂Java面试故事实录:三轮场景化技术提问与详细答案解析
java·spring boot·微服务·面试·aigc·电商·内容社区