有同学在群里咨询,想通过短信精准营销,实现用户收到短信后,点击打开短信链接就自动调起微信小程序或APP,请问丁老师这个可以实现吗?该如何实现呢?今天丁老师对这个问题进行解答。
短信链接打开微信小程序和APP的原理
通过群发短信,然后用户点击短信链接,就可以打开微信小程序或者APP,这种方式其实实现起来很简单。
1.原理是在短信中添加一个url网址,最好是短网址,不要太长。
2.这个网址打开后是一个静态的html页面,这个页面包含可以打开微信小程序或者APP的代码。
3.这个网址的网页可以进行UI设计,也可以不设计。设计美化后的网页可以做成类似拼多多的那种,引导用户手动打开微信小程序或APP。也可以不设计,直接自动触发代码调用打开微信小程序或APP。
短信链接打开微信小程序的方法
1.通过微信的Url Scheme实现。Url Scheme是一种专属的url格式,可以用来唤醒小程序。这个url需要服务端调用微信接口生成,也可以直接在小程序管理后台生成。生成后访问这个链接即可打开小程序。
2.通过Url Link实现,Url Link就是普通的url网址,由微信服务端生成的Url Link,也可以用来唤醒小程序。这个url link也需要服务端调用微信接口生成,生成后访问这个链接即可打开小程序。
3.在生成以上两个链接后,可以将短信中的短网址链接,自动跳转到url scheme或url link,也可以在打开短网址链接后,自动触发这两个url,以实现微信小程序的调用打开。
短信链接打开APP的方法
1.短信跳转的网址,增加a链接,引导用户点击,a链接的href中需要填写这个app的url scheme信息,比如
#该链接会打开淘宝,并传递id为123456的值过去
<a href="taobao://item?id=123456"></a>2.短信跳转的网址,通过JS代码判断,如果本地已安装APP就自动打开,如果没有安装就引导下载安装。
<button id="openOrInstallApp">打开/安装我的App</button>
<script>
//配置项(根据自己的App修改)
const APP_CONFIG = {
//Android Scheme
androidScheme: 'myapp://page/home',
//iOS Scheme
iosScheme: 'myapp://page/home',
//iOS Universal Link(可选,无则用Scheme)
iosUniversalLink: 'https://your-domain.com/open/app',
//应用商店链接
//iOS App Store地址
appStoreUrl: 'https://apps.apple.com/cn/app/xxx/id123456789',
//腾讯应用宝地址
androidStoreUrl: 'https://a.app.qq.com/o/simple.jsp?pkgname=com.xxx.xxx',
//自定义下载地址
fallbackUrl: 'https://www.xxx.com/app/download'
};
//判断设备类型
function getDeviceType(){
const ua = navigator.userAgent.toLowerCase();
if (ua.includes('iphone') || ua.includes('ipad')) return 'ios';
if (ua.includes('android')) return 'android';
return 'other';
}
//唤起App核心方法
async function openApp(){
const device = getDeviceType();
let isAppOpened = false;
//监听页面隐藏事件
const onPageHidden = () =>{
isAppOpened = true;
//移除监听,避免重复触发
document.removeEventListener('visibilitychange', onPageHidden);
window.removeEventListener('pagehide', onPageHidden);
};
document.addEventListener('visibilitychange', onPageHidden);
window.addEventListener('pagehide', onPageHidden);
try {
if (device === 'ios' && APP_CONFIG.iosUniversalLink) {
//1.iOS优先用Universal Link(无拦截)
window.location.href = APP_CONFIG.iosUniversalLink;
}
else {
//2.用Scheme唤起
const scheme = device === 'ios' ? APP_CONFIG.iosScheme : APP_CONFIG.androidScheme;
//创建隐藏iframe触发Scheme
const iframe = document.createElement('iframe');
iframe.style.display = 'none';
iframe.src = scheme;
document.body.appendChild(iframe);
setTimeout(() => document.body.removeChild(iframe), 2000);
//同时直接跳转Scheme
window.location.href = scheme;
}
//3. 延迟检测,未唤起则跳转安装页
setTimeout(() =>{
if (!isAppOpened){
let installUrl = APP_CONFIG.fallbackUrl;
if (device === 'ios') installUrl = APP_CONFIG.appStoreUrl;
if (device === 'android') installUrl = APP_CONFIG.androidStoreUrl;
window.location.href = installUrl;
}
}, 1800);
}
catch (e) {
//异常时直接跳转兜底页
window.location.href = APP_CONFIG.fallbackUrl;
}
}
// 绑定按钮点击事件
document.getElementById('openOrInstallApp').addEventListener('click', openApp);
</script>备注
以上方式不仅可以实现从短信中调用打开微信小程序、APP,也可以将此方法应用到电子邮件、二维码等营销网页中,只要引导用户访问URL网页,最终都可以实现调用打开微信小程序和APP。
方式一、通用卸载命令openclaw uninstall --all --yes --non-interactive #如果不行,则执行 npx -y openclaw uninstall --all --yes --non-inter...
最近网络形势很严峻,很多网站要么感染木马病毒,要么是被黑客攻击,很大一部分都是通过网站的上传入口进行渗透,伪造合法文件,上传包含php、html、js等脚本文件,然后远程执行进行破坏。为了解决这个问题,一方面是在程序端上传文件部分进行文...
上期文章介绍了《vscode显示函数列表方法》,很多同学在使用后反馈,这个功能真好,可以对函数进行快速导航定位了。但是这个函数列表,把参数也显示出来了,有些函数参数非常多,这样的话显示起来不是很直观,有什么办法能隐藏这些函数吗?如图:其...
在开发微信小程序时,涉及到获取用户位置的业务部分,需要使用wx.getLocation方法。但是wx.getLocation接口很难申请,基本上申请了都不给通过,主要是因为申请该方法,需要提供相关场景的图片、视频、业务流程说明,并且使用...
软件介绍Basgito是基于Laravel框架的免费电子商务平台,可以快速搭建自己企业专属的电子商务交易平台,适用于中小型外贸企业。该电商平台拥有无头laravel商务(headless laravel commerce)的强大功能,可以快...
普通账号个人认证号企业认证号蓝色认证标识薯条推广聚光平台效果广告普通应商业合作以KOL/KOC身份和品牌合作以品牌方身份发起起合作开设店铺个人店铺或个体户(不支持港澳台公司申请)旗舰店店或专卖店(支持港澳台公司申请)主动私信每天10位陌生用...
挺不错的浏览器,强加入了edge image viewer图片浏览器,感觉不是那么好,对于开发者来说,更想要原生的东西。包括微信网页版里的表情图片,用edge image viewer打开的话,无法保存为gif格式,即使保存了,也只是第一帧...
fontawesome所有图标class类名单,适用于4.7.0版本。总计有593个图标class类(包含别名):fa-500pxfa-address-bookfa-address-book-ofa-address-cardfa-addre...