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)
相关推荐
wxm6312 小时前
TCP监听--监听指定IP的端口号
java·网络·tcp/ip
ego.iblacat2 小时前
MySQL 主从复制与读写分离
android·mysql·adb
csdn2015_2 小时前
java 把对象转化为json字符串
java·前端·json
想带你从多云到转晴2 小时前
03、数据结构与算法--单向链表
java·数据结构·算法
无籽西瓜a2 小时前
【西瓜带你学设计模式 | 第七期 - 适配器模式】适配器模式 —— 类适配器与对象适配器实现、优缺点与适用场景
java·后端·设计模式·软件工程·适配器模式
Oliver_LaVine2 小时前
idea启动后端项目-控制台中文乱码处理
java·ide
Flittly2 小时前
【SpringAIAlibaba新手村系列】(6)PromptTemplate 提示词模板与变量替换
java·spring boot·agent
Android系统攻城狮2 小时前
Android tinyalsa深度解析之pcm_params_get_period_size_max调用流程与实战(一百七十二)
android·pcm·tinyalsa·音频进阶
yaaakaaang2 小时前
3.springboot,用eclipse轻松创建~
java·spring boot·eclipse