H5网页跳转打开微信小程序详解(含完整代码)

图片

限制条件:

  1. 目前仅支持在微信内打开H5页面;

  2. 已认证的服务号,服务号绑定“JS接口安全域名”下的网页可使用此标签跳转任意合法合规的小程序;

  3. 已认证的非个人主体的小程序,使用小程序云开发的静态网页托管绑定的域名下的网页,可以使用此标签跳转任意合法合规的小程序。

 

 

 

01

 

绑定安全域名

 

登录微信公众平台进入【公众号设置】-->【功能设置】里设置好 “js接口安全域名”。

 

图片

 

02

 

IP白名单设置

登录微信公众平台进入【开发】-->【基本配置】,这里填写你服务器的IP

 

03

 

完整代码

后面直接伸手就给,已经给大家准备了完整的DEMO,填一下自己的信息就可以了。公众号回复『h5跳转小程序』,即可获取完整代码。遇到其他问题可以留言,看到了第一时间会回复大家。

 

图片

 

图片

 

<!--=========================================================公众号:被动睡后收入==========================================================-->
<!--==========================================================PHP --start==========================================================-->
<?php
// 微信 JS 接口签名校验工具: https://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign
$appid = 'AppID'; //填入服务号AppID
$secret = 'AppSecret'; //填入服务号AppSecret

// 获取token
$token_data = file_get_contents('./wechat_token.txt');
if (!empty($token_data)) {
    $token_data = json_decode($token_data, true);
}
$time = time() - $token_data['time'];
if ($time > 3600) {
    $token_url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={$appid}&secret={$secret}";
    $token_res = https_request($token_url);
    $token_res = json_decode($token_res, true);
    $token = $token_res['access_token'];
    $data = array(
        'time' => time(),
        'token' => $token
    );
    $res = file_put_contents('./wechat_token.txt', json_encode($data));
    if ($res) {
        echo '更新 token 成功';
    }
} else {
    $token = $token_data['token'];
}

// 获取ticket
$ticket_data = file_get_contents('./wechat_ticket.txt');
if (!empty($ticket_data)) {
    $ticket_data = json_decode($ticket_data, true);
}
$time = time() - $ticket_data['time'];
if ($time > 3600) {
    $ticket_url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token={$token}&type=jsapi";
    $ticket_res = https_request($ticket_url);
    $ticket_res = json_decode($ticket_res, true);
    $ticket = $ticket_res['ticket'];
    $data = array(
        'time' => time(),
        'ticket' => $ticket
    );
    $res = file_put_contents('./wechat_ticket.txt', json_encode($data));
    if ($res) {
        echo '更新 ticket 成功';
    }
} else {
    $ticket = $ticket_data['ticket'];
}

// 进行sha1签名
$timestamp = time();
$nonceStr = createNonceStr();

// 注意 URL 建议动态获取(也可以写死).
$protocol = (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off' || $_SERVER['SERVER_PORT'] == 443) ? "https://" : "http://";
$url = "$protocol$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]"; // 调用JSSDK的页面地址

// $url = $_SERVER['HTTP_REFERER']; // 前后端分离的, 获取请求地址(此值不准确时可以通过其他方式解决)
$str = "jsapi_ticket={$ticket}&noncestr={$nonceStr}&timestamp={$timestamp}&url={$url}";
$sha_str = sha1($str);

function createNonceStr($length = 16)
{
    $chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
    $str = "";
    for ($i = 0; $i < $length; $i++) {
        $str .= substr($chars, mt_rand(0, strlen($chars) - 1), 1);
    }
    return $str;
}

/**
 * 模拟 http 请求
 * @param  String $url 请求网址
 * @param  Array $data 数据
 */
function https_request($url, $data = null)
{
    // curl 初始化
    $curl = curl_init();
    // curl 设置
    curl_setopt($curl, CURLOPT_URL, $url);
    curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);
    curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);
    // 判断 $data get  or post
    if (!empty($data)) {
        curl_setopt($curl, CURLOPT_POST, 1);
        curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
    }
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
    // 执行
    $res = curl_exec($curl);
    curl_close($curl);
    return $res;
}

?>
<!--==========================================================PHP --end==========================================================-->

<!--==========================================================HTML --start==========================================================-->
<html>
<head>
    <title>被动睡后收入-->微信公众号</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <meta name="viewport" content="width=device-width,initial-scale=0.5">
</head>
<body>
<div id="app">
    <wx-open-launch-weapp
            id="launch-btn"
            username="gh_xxx"  <!-- 需要跳转的小程序的原生id gh_开头 -->
            path="pages/index/index.html?uid=16" <!-- 需要跳转的小程序的路径以及参数 -->
    >
        <template>
            <style>
                .btn {
                    padding: 12px;
                    width: 10rem;
                    height: 10rem;
                }
            </style>
            <div style="text-align: center;align-items: center;margin: 8rem">
                <button class="btn">打开小程序</button>
            </div>
        </template>
    </wx-open-launch-weapp>
    <script>
        var btn = document.getElementById('launch-btn');
        btn.addEventListener('launch', function (e) {
            console.log('success');
        });
        btn.addEventListener('error', function (e) {
            console.log('fail', e.detail);
        });
    </script>
</div>
<script type="text/javascript" src="https://res2.wx.qq.com/open/js/jweixin-1.6.0.js"></script>
<script type="text/javascript">
    wx.config({
        debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
        appId: '<? echo $appid ?>', // 必填,公众号的唯一标识
        timestamp: <? echo $timestamp ?>, // 必填,生成签名的时间戳
        nonceStr: '<? echo $nonceStr ?>', // 必填,生成签名的随机串
        signature: '<? echo $sha_str ?>',// 必填,签名
        jsApiList: ['onMenuShareTimeline', 'scanQRCode'],// 必填,需要使用的JS接口列表,
        openTagList: ['wx-open-launch-weapp']
    });
    wx.ready(function () {
        console.log('接口配置成功');
    });
</script>
</body>
</html>

<!--==========================================================HTML --end==========================================================-->

 

查看APPID、原始ID、页面路径请详见文末更多推荐

  • 3
    点赞
  • 43
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 17
    评论
好的,以下是实现 H5 网页跳转微信小程序完整代码: ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>跳转小程序</title> </head> <body> <button onclick="jumpToMiniProgram()">跳转微信小程序</button> <script> // 小程序的 appid var appid = '小程序的appid'; // 跳转小程序的页面路径 var path = '/pages/index/index'; // 监听“跳转小程序”的按钮点击事件 function jumpToMiniProgram() { // 判断是否在微信浏览器中打开 if (navigator.userAgent.toLowerCase().match(/MicroMessenger/i) == 'micromessenger') { // 如果在微信浏览器中打开,则使用微信 JS-SDK 跳转 // 获取微信 JS-SDK 的配置信息 var xhr = new XMLHttpRequest(); xhr.open('GET', 'https://yourserver/getJsSdkConfigInfo.php?url=' + encodeURIComponent(location.href.split('#')[0]), true); xhr.onreadystatechange = function () { if (xhr.readyState == 4 && xhr.status == 200) { var data = JSON.parse(xhr.responseText); if (data && data.appId) { // 配置微信 JS-SDK 的权限验证参数 wx.config({ debug: false, appId: data.appId, timestamp: data.timestamp, nonceStr: data.nonceStr, signature: data.signature, jsApiList: ['checkJsApi', 'chooseImage', 'previewImage', 'uploadImage', 'downloadImage', 'getNetworkType', 'getLocation', 'hideOptionMenu', 'showOptionMenu', 'hideMenuItems', 'showMenuItems', 'hideAllNonBaseMenuItem', 'showAllNonBaseMenuItem', 'closeWindow', 'scanQRCode', 'chooseWXPay', 'openProductSpecificView', 'addCard', 'chooseCard', 'openCard', 'openLocation', 'onMenuShareTimeline', 'onMenuShareAppMessage'] }); // 配置微信 JS-SDK 的权限验证成功后的回调函数 wx.ready(function () { // 调用微信 JS-SDK 的跳转小程序接口 wx.miniProgram.navigateTo({ appId: appid, path: path, extraData: { // 携带的参数 key1: 'value1', key2: 'value2' }, success: function () { // 跳转成功的回调函数 } }); }); } } }; xhr.send(); } else { // 如果没有在微信浏览器中打开,则提示用户在微信中打开 alert('请在微信中打开!'); } } </script> <script src="https://res.wx.qq.com/open/js/jweixin-1.4.0.js"></script> </body> </html> ``` 需要注意的是,该代码需要在微信公众平台中进行配置,具体可以参考 [微信官方文档](https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/Wechat_Open_JS-SDK.html)。同时,该代码需要在服务器中进行部署,具体可以参考 [微信官方文档](https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/Wechat_Open_Platform.html)。
评论 17
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿桂

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值