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)
相关推荐
针叶14 小时前
Google Play加固保护导致的崩溃
android·安全·google
AskHarries15 小时前
系统提示词、开发者指令和用户输入的优先级
java·前端·数据库
daidaidaiyu15 小时前
ThingsBoard 规则链系统源码分析和自定义定时器
java
小毛驴85016 小时前
spring-boot-maven-plugin,maven-compiler-plugin 功能对比
java·python·maven
csdn_aspnet16 小时前
Java 霍尔分区算法(Hoare‘s Partition Algorithm)
java·开发语言·算法
霸道流氓气质16 小时前
通义灵码 IDEA 插件完全使用指南
java·ide·intellij-idea
执明wa16 小时前
Android Studio 项目目录结构全方位详解
android·ide·android studio
诸葛务农16 小时前
道路行驶条件下电动汽车永磁电机的有效使用寿命及永磁体的失效和回收再利用(下)
java·开发语言·算法
Percep_gan16 小时前
Java8中的stream的测试使用
java
砍材农夫17 小时前
物联网实战:Spring Boot MQTT | MQTT 设备模拟器演示(附源码)
java·spring boot·后端·物联网·spring·netty