更新记录
1.0.6(2025-10-15)
调整iOS扩张配置方式。
1.0.5(2024-09-26)
修复VPN事件持续触发不生效问题。
1.0.4(2024-09-08)
setConfig接口新增是否开启通知栏保活的参数。
查看更多平台兼容性
uni-app(4.74)
| Vue2 | Vue3 | Chrome | Safari | app-vue | app-nvue | app-nvue插件版本 | Android | Android插件版本 | iOS | iOS插件版本 | 鸿蒙 |
|---|---|---|---|---|---|---|---|---|---|---|---|
| × | × | × | × | × | √ | 1.0.1 | 5.0 | 1.0.1 | 12 | 1.0.1 | × |
| 微信小程序 | 支付宝小程序 | 抖音小程序 | 百度小程序 | 快手小程序 | 京东小程序 | 鸿蒙元服务 | QQ小程序 | 飞书小程序 | 快应用-华为 | 快应用-联盟 |
|---|---|---|---|---|---|---|---|---|---|---|
| × | × | × | × | × | × | × | × | × | × | × |
uni-app x(4.74)
| Chrome | Safari | Android | Android插件版本 | iOS | iOS插件版本 | 鸿蒙 | 微信小程序 |
|---|---|---|---|---|---|---|---|
| × | × | 5.0 | 1.0.1 | 12 | 1.0.1 | × | × |
概述
XF-aleafVPNUTS实现了iOS平台集成Network Extensions集成leaf、Android集成leaf实现VPN功能(小米手机上使用的请加uniPush,会在一定程度上对App进行保活)。
iOS插件必须看的说明
权限配置
"app-ios": {
"distribute": {
"modules": {},
"icons": {},
"splashScreens": {},
"privacyDescription": {
"NSSystemExtensionUsageDescription": "权限申请描述信息"
}
}
}
appIdxxx.PacketTunnel : 扩展ID格式 group.appIdxxx : 组名称格式
根目录下创建:nativeResources\ios 并放置ios-extension.json、ios-PacketTunnelExt.mobileprovision文件
ios-extension.json 内容如下:
{
"PacketTunnel.appex": {
"identifier":"com.app.xiaofei.001.PacketTunnel",
"profile":"ios-PacketTunnelExt.mobileprovision",
"entitlements":{
"com.apple.developer.networking.networkextension":["packet-tunnel-provider"],
"com.apple.security.application-groups":["group.com.app.xiaofei.001"]
}
}
}
ios-PacketTunnelExt.mobileprovision 文件为扩展appIdxxx.PacketTunnel的描述文件(请不要修改文件名称只替换描述文件)
调整插件内部的UTS.entitlements文件内容
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>com.apple.developer.networking.networkextension</key>
<array>
<string>packet-tunnel-provider</string>
</array>
<key>com.apple.security.application-groups</key>
<array>
<string>group.com.app.xiaofei.001</string>
</array>
</dict>
</plist>
插件接口
setConfig
配置VPN参数
uni-app项目中(nvue)调用示例:
import { setConfig } from "@/uni_modules/XF-aleafVPNUTS"
setConfig({
conf: "[General]\n loglevel = trace\n logoutput = REPLACE-LEAF-LOG-FILE\n dns-server = 223.5.5.5, 114.114.114.114\n tun-fd = REPLACE-ME-WITH-THE-FD\n routing-domain-resolve = true\n [Proxy]\n Direct = direct\n Proxy = trojan, www.demo.vip, 443, password=demo, sni=www.demo.vip\n [Rule]\n FINAL, Proxy",
complete: (res) => {
console.log(res)
}
});
uni-app x项目(uvue)中调用示例:
import { setConfig } from "@/uni_modules/XF-aleafVPNUTS";
import { ConfigOptions } from "@/uni_modules/XF-aleafVPNUTS/utssdk/interface.uts";
let options = {
conf: "[General]\n loglevel = trace\n logoutput = REPLACE-LEAF-LOG-FILE\n dns-server = 223.5.5.5, 114.114.114.114\n tun-fd = REPLACE-ME-WITH-THE-FD\n routing-domain-resolve = true\n [Proxy]\n Direct = direct\n Proxy = trojan, www.demo.vip, 443, password=demo, sni=www.demo.vip\n [Rule]\n FINAL, Proxy",
complete: (res : any) => {
console.log(res)
}
} as ConfigOptions;
setConfig(options);
可用性
iOS、Android系统
可提供的1.0.0及更高版本
startVPN
开启VPN服务
uni-app项目中(nvue)调用示例:
import { startVPN } from "@/uni_modules/XF-aleafVPNUTS"
startVPN({
complete: (res) => {
console.log(res)
}
});
uni-app x项目(uvue)中调用示例:
import { startVPN } from "@/uni_modules/XF-aleafVPNUTS";
import { VPNOptions } from "@/uni_modules/XF-aleafVPNUTS/utssdk/interface.uts";
let options = {
complete: (res : any) => {
console.log(res)
}
} as VPNOptions;
startVPN(options);
可用性
iOS、Android系统
可提供的1.0.0及更高版本
stopVPN
停止VPN服务
uni-app项目中(nvue)调用示例:
import { stopVPN } from "@/uni_modules/XF-aleafVPNUTS"
stopVPN({
complete: (res) => {
console.log(res)
}
});
uni-app x项目(uvue)中调用示例:
import { stopVPN } from "@/uni_modules/XF-aleafVPNUTS";
import { VPNOptions } from "@/uni_modules/XF-aleafVPNUTS/utssdk/interface.uts";
let options = {
complete: (res : any) => {
console.log(res)
}
} as VPNOptions;
stopVPN(options);
可用性
iOS、Android系统
可提供的1.0.0及更高版本
addStatusCallback
监听VPN状态通知
uni-app项目中(nvue)调用示例:
import { addStatusCallback } from "@/uni_modules/XF-aleafVPNUTS"
addStatusCallback({
complete: (res) => {
console.log(res)
}
});
uni-app x项目(uvue)中调用示例:
import { addStatusCallback } from "@/uni_modules/XF-aleafVPNUTS";
import { VPNOptions } from "@/uni_modules/XF-aleafVPNUTS/utssdk/interface.uts";
let options = {
complete: (res : any) => {
console.log(res)
}
} as VPNOptions;
addStatusCallback(options);
可用性
iOS、Android系统
可提供的1.0.0及更高版本
isConnected
是否已连接
uni-app项目中(nvue)调用示例:
import { isConnected } from "@/uni_modules/XF-aleafVPNUTS"
isConnected();
uni-app x项目(uvue)中调用示例:
import { isConnected } from "@/uni_modules/XF-aleafVPNUTS";
isConnected();
可用性
iOS、Android系统
可提供的1.0.0及更高版本
getConfig
获取正在运行的配置文件内容
uni-app项目中(nvue)调用示例:
import { getConfig } from "@/uni_modules/XF-aleafVPNUTS"
getConfig();
uni-app x项目(uvue)中调用示例:
import { getConfig } from "@/uni_modules/XF-aleafVPNUTS";
getConfig();
可用性
iOS、Android系统
可提供的1.0.0及更高版本
getLog
获取日志信息
uni-app项目中(nvue)调用示例:
import { getLog } from "@/uni_modules/XF-aleafVPNUTS"
getLog();
uni-app x项目(uvue)中调用示例:
import { getLog } from "@/uni_modules/XF-aleafVPNUTS";
getLog();
可用性
iOS、Android系统
可提供的1.0.0及更高版本

收藏人数:
购买源码授权版(
试用
赞赏(0)
下载 192
赞赏 0
下载 10668482
赞赏 1797
赞赏
京公网安备:11010802035340号