zoukankan      html  css  js  c++  java
  • 微信JSSDK使用步骤(用于在微信浏览器中自定义分享,分享到朋友圈,拍照,扫一扫等功能)

    一、使用JSSDK需要一个公众号(需要认证!):

    (1)、把自己项目的服务器地址输入。

    (2)、把MP_verify_m7Qp93BAuIGDWRVO.txt  文件下载下来,放到该服务器域名指向的根目录!

       这样基础工作就完成了!

     二、后台生成前端需要的参数!

      (1)、前端想要实现分享、扫一扫等等需要的参数!

     wx.config({
            debug: false,//是否开启调试功能,这里关闭!
            appId: jssdk.appId,//appid
            timestamp: parseInt(jssdk.timestamp), //时间戳
            nonceStr: jssdk.nonceStr, //生成签名的随机字符串
            signature: jssdk.signature,//签名
            jsApiList: [
                "onMenuShareTimeline",
                "onMenuShareAppMessage"
            ]
        });

     (2)、后端代码获取参数实现如下:

             微信官方后台代码:   http://demo.open.weixin.qq.com/jssdk/sample.zip

    三、前端代码封装实现:

    (一)、页面中引入!

          <script src='https://res.wx.qq.com/open/js/jweixin-1.0.0.js'></script>
     
    (二)、请求后台的接口,获取步骤二中展示的需要的参数,然后调用如下的封装的函数即可实现自定义分享,扫一扫、拍照等功能!
    /**
     * @param {jssdk为从后台请求过来的各种信息,包括appId,timestamp,nonceStr,signature} jssdk 
     * 以上4个参数,需要后台在公众号相关平台进行配置,然后得出!前端页面必须放在服务号配置的域名下面才可以保证成功!
     * @param {为js对象格式,options里面包含自定义的title,desc,link,imgUrl} options 
     * 引入jweixin文件后,直接调用该函数,即可实现自定义分享功能
     */
    
    
    function shareJs(jssdk, options) {
        wx.config({
            debug: false,//是否开启调试功能,这里关闭!
            appId: jssdk.appId,//appid
            timestamp: parseInt(jssdk.timestamp), //时间戳
            nonceStr: jssdk.nonceStr, //生成签名的随机字符串
            signature: jssdk.signature,//签名
            jsApiList: [
                "onMenuShareTimeline",
                "onMenuShareAppMessage"
            ]
        });
        var defaults = {
            title: "分享的标题",
            desc: "分享的描述",
            link: location.href, //分享页面地址,不能为空,这里可以传递参数!!!!!!!
            imgUrl: 'https://tup.iheima.com/sport.png', //分享是封面图片,不能为空
            success: function () { }, //分享成功触发
            cancel: function () { } //分享取消触发,需要时可以调用
        }
        // 合并对象,后面的替代前面的!
        options = Object.assign({}, defaults, options);
        wx.ready(function () {
            var thatopts = options;
            // 分享到朋友圈
            wx.onMenuShareTimeline({
                title: thatopts.title, // 分享标题
                desc: thatopts.desc, // 分享描述
                link: thatopts.link, // 分享链接
                imgUrl: thatopts.imgUrl, // 分享图标
                success: function () {
                    // alert("成功");
                },
                cancel: function () {
                    // alert("失败")
                }
            });
            // 分享给朋友
            wx.onMenuShareAppMessage({
                title: thatopts.title, // 分享标题
                desc: thatopts.desc, // 分享描述
                link: thatopts.link, // 分享链接
                imgUrl: thatopts.imgUrl, // 分享图标
                success: function () {
                    // alert("成功");
                },
                cancel: function () {
                    // alert("失败")
                }
            });
        });
    }
  • 相关阅读:
    在浏览器中输入URL后,执行的全部过程。会用到哪些协议?(一次完整的HTTP请求过程)
    线程的5种状态详解
    哈希表(Hash Table)原理及其实现 【转载】
    notify() 和 notifyAll() 有什么区别? wait()
    B树、B-树、B+树、B*树介绍,和B+树更适合做文件索引的原因 【转】
    pthread_join和pthread_detach的用法 【】转载】
    什么是进程?什么是线程
    进程间的五种通信方式介绍【转载】
    81. Search in Rotated Sorted Array II
    33. Search in Rotated Sorted Array
  • 原文地址:https://www.cnblogs.com/teamemory/p/9798633.html
Copyright © 2011-2022 走看看