【uniapp】在UniApp中检测手机是否安装了某个应用

1. 使用plus.runtime.isApplicationExist(仅限App端)

javascript 复制代码
// 判断应用是否安装
function checkAppInstalled(packageName) {
    if (uni.getSystemInfoSync().platform === 'android' || uni.getSystemInfoSync().platform === 'ios') {
        // 仅App端可用
        if (typeof plus !== 'undefined') {
            return new Promise((resolve, reject) => {
                plus.runtime.isApplicationExist({
                    pname: packageName, // Android包名或iOS的URL Scheme
                    action: '' // iOS可选
                }, (exist) => {
                    resolve(exist)
                })
            })
        }
    }
    return Promise.resolve(false)
}

// 使用示例
checkAppInstalled('com.tencent.mm') // 检测微信是否安装
    .then(installed => {
        console.log('应用是否安装:', installed)
    })

2. 使用URL Scheme尝试唤醒应用(跨平台)

javascript 复制代码
function checkAppByScheme(scheme) {
    return new Promise((resolve) => {
        // 尝试打开应用
        window.location.href = scheme
        
        // 设置超时检测
        setTimeout(() => {
            // 如果还在当前页面,则认为应用未安装
            if (document.hidden || document.webkitHidden) {
                resolve(true)
            } else {
                resolve(false)
            }
        }, 2000)
    })
}

// 使用示例(需要真实URL Scheme)
checkAppByScheme('weixin://')
    .then(installed => {
        console.log('应用是否安装:', installed)
    })

3. 使用uni.navigateToMiniProgram(检测微信小程序)

javascript 复制代码
uni.navigateToMiniProgram({
  appId: '目标小程序appid',
  success(res) {
    // 可以打开,说明已安装
    console.log('小程序已安装')
  },
  fail(err) {
    // 打开失败,可能未安装
    console.log('小程序未安装或打开失败', err)
  }
})

注意事项

平台限制

  • Android需要知道目标应用的包名

  • iOS需要知道目标应用的URL Scheme

隐私政策

  • 在iOS上,苹果对应用检测有严格限制,可能需要用户交互才能检测

上架审核

  • 使用这些方法可能会影响应用商店审核,特别是如果检测后引导用户去下载

H5端限制

  • 在H5端无法直接检测应用是否安装,只能通过尝试跳转的方式间接判断

建议根据实际需求选择合适的方法,并处理好各平台的兼容性问题。

相关推荐
影子打怪1 天前
uniapp项目中,通过renderjs的方式展示地图,及其标点、轨迹展示、轨迹回放
uni-app
iOS阿玮1 天前
想偷懒购买现成的应用,结果一更新就遇到了4.3a!
uni-app·app·apple
HashTang1 天前
【AI 编程实战】第 4 篇:一次完美 vs 五轮对话 - UnoCSS 配置的正确姿势
前端·uni-app·ai编程
雯0609~2 天前
uni-app:防止重复提交
前端·javascript·uni-app
2501_915909062 天前
苹果应用加密方案的一种方法,在没有源码的前提下,如何处理 IPA 的安全问题
android·安全·ios·小程序·uni-app·iphone·webview
百锦再2 天前
与AI沟通的正确方式——AI提示词:原理、策略与精通之道
android·java·开发语言·人工智能·python·ui·uni-app
2501_915909062 天前
iOS 项目中常被忽略的 Bundle ID 管理问题
android·ios·小程序·https·uni-app·iphone·webview
2501_915921432 天前
iOS App 测试的工程化实践,多工具协同的一些尝试
android·ios·小程序·https·uni-app·iphone·webview
咸虾米_2 天前
uniapp+unicloud实战项目,九两酒微信小程序商城及后台管理系统前后端部署运行步骤
微信小程序·uni-app·uniapp实战项目·unicloud云开发·vue3后台管理
怀君2 天前
Uniapp——Android离线打包之更换启动屏和App图标
uni-app