`

微信API - 朋友(圈)分享,设置转分享内容

 
阅读更多

微信分享设置

 

 

用异步ajax的方式获取数字签名
异步的方式好
1、前后端分离啊
2、一个服务可以供多个微信公众帐号的数字签名服务
 
在服务器端用NodeJS跑起一个数字签名生成服务,web端用ajax方式请求NodeJS服务获取数字签名信息
得到信息后配置微信JS-SDK
烟雨林-关注程序员的IT科技博客
 
 
步骤
 
第一步 认证的微信公众帐号
首先你得拥有一个通过认证了的微信公众号或者开发者帐号,没有通过认证的公众帐号。
数字签名认证也能成功,但是分享信息是无法设置成功的;
 
第二步 添加安全域名
在公众帐号平台后台添加app运行的域名地址,可以理解为为某个域名添加白名单功能
以我们公司旗下的榕树下为例:
微信公众号是:榕树下,添加了game.4gshu.com为安全域名,
那么我在game.4gshu.com上的网页可以使用榕树下公众帐号的数字签名了
 
第三步 生成数字签名
在微信公众平台后台上面能找到一个 appid 及 secret字符串
通过这两个数据,请求微信提供的两个公开API地址,
生成对应的access_token后再生成ticket再通过规则加密成数字签名
注意,数字签名必须在服务端生成,这里我以NodeJS来实现
数字签名具体生成过程,NodeJS版本
烟雨林-关注程序员的IT科技博客
1、获取微信签名所需的access_token
https.get('https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=你的appid写在这里&secret=你的secret写在这里', function(_res) {
 // 这个异步回调里可以获取access_token
 })
2、获取微信签名所需的ticket
https.get('https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=上一步中获取的access_token&type=jsapi', function(_res){
 // 这个异步回调里可以获取ticket
});
3、生成数字签名具体方法 ticket、 noncestr、timestamp、url
通过微信的规则用sha1加密 noncestr和timestamp在微信官方sample包中有具体的生成方法函数
 // noncestr
 var createNonceStr = function() {
 return Math.random().toString(36).substr(2, 15);
 };
 // timestamp
 var createTimeStamp = function () {
 return parseInt(new Date().getTime() / 1000) + '';
 };
也可以参考我代码中的代码
 // 计算签名方法
 var calcSignature = function (ticket, noncestr, ts, url) {
 var str = 'jsapi_ticket=' + ticket + '&noncestr=' + noncestr + '×tamp='+ ts +'&url=' + url;
 shaObj = new jsSHA(str, 'TEXT');
 return shaObj.getHash('SHA-1', 'HEX');
 }
var signature = calcSignature(ticket, noncestr, timestamp, url);
4、返回输出signature数字签名以及在生成数字签名时用到的timestamp、nonceStr、url、
及appid 因为在客户内初始化微信JS-SDK中还要用到   
5、至此数字签名生成成功   

第四步 在web中如何使用数字签名? 

1、引入微信JS-SDK http://res.wx.qq.com/open/js/jweixin-1.0.0.js
(http://res.wx.qq.com/open/js/jweixin-1.0.0.js)   
2、请求服务器获取数字签名 在web上用ajax方式请求NodeJS服务地址,
请求时将当前web地址url上传至服务器 服务器生成数字签名后返回:
 signature,timestamp, appid, nonceStr 这四个数据用于配置微信JS-SDK
wx.config({
  debug: true,
  appId: appid,
  timestamp: timestamp,
  nonceStr: nonceStr,
  signature: signature,
  jsApiList: [
  'checkJsApi',
  'onMenuShareTimeline',
  'onMenuShareAppMessage',
  'onMenuShareQQ',
  'onMenuShareWeibo',
  'hideMenuItems',
  'chooseImage'
  ]
 });
3、在wx.ready内调用API
wx.ready(function(){
  var sdata = {
  title: '那年|时光遗忘了,文字却清晰地复刻着',
  desc: '那年|时光遗忘了,文字却清晰地复刻着',
  link: 'http://game.4gshu.com/deep-love/index2.html',
  imgUrl: 'http://game.4gshu.com/xuangedan/other-project/2015-01-06/img/share-wx-logo.jpg',
  success: function () {
  alert('用户确认分享后执行的回调函数');
  },
  cancel: function () {
  alert('用户取消分享后执行的回调函数');
  }
  };
  wx.onMenuShareTimeline(sdata);
  wx.onMenuShareAppMessage(sdata);
 });
4、搞定     
关于数字签名过期与微信API的1w次请求的限制问题   
由于微信提供的两个数字签名生成API有7200秒的有效期,并且暂时有1w次的限制,
所以在我们自己服务器上需要将数字签名缓存   
逻辑是: 如果用户请求时没缓存中没有数字签名,那么请求执行第三步 
生成数字签名 

如果缓存中有,并且是在2小时内那么直接返回数字签名信息,
不去请求微信服务器 如果缓存中的数字签名过期了(超过2小时)则还是执行第三步 生成数字签名 

注意:由于微信规定地址栏中的参数发生变化都认作是新的请求地址,数字签名也需要重新生成。
新生成的数字签名将存入cachedSignatures对象内 缓存中的数据结构将url设为key 数据结构如下:
var cachedSignatures = {
 'http://game.4gshu.com/': {
  appid: ’微信认证帐号的的appid'
  ,secret: '微信认证帐号的secret'
  ,timestamp: '1421135250'
  ,noncestr: 'ihj9ezfxf26jq0k'
 }
 }

 

 

(function() {
    var JSSDK_URL = "https://res.wx.qq.com/open/js/jweixin-1.0.0.js";
    var _getParameter = function(param) {
        var reg = new RegExp('[&,?]' + param + '=([^\\&]*)', 'i');
        var value = reg.exec(location.search);
        return value ? value[1] : '';
    };
    
    var WXCFG = {
        appId: 'xxxxxxxxxxxxxxxxxxx',
        weappNo: 'XX',
        openid: 'xxxxxxxxxxxxxxxxxxxx',
        ucp_uri: 'https://www.abc.com/it-pir/'
    };
    var loadscript = function(url, callback) {
        var script = document.createElement('script');
        script.type = 'text/javascript';
        if (callback)
            script.onload = script.onreadystatechange = function() {
                if (script.readyState && script.readyState != 'loaded' && script.readyState != 'complete')
                    return;
                script.onreadystatechange = script.onload = null;
                callback();
            };
        script.src = url;
        document.getElementsByTagName('head')[0].appendChild(script);
    };
    var _ts = new Date().getTime();
    var _url = WXCFG.ucp_uri + "/getSignature?weappNo=" + WXCFG.weappNo + "&openid=" + WXCFG.openid + "&callback=ucp_callback" + _ts;
    var _signature;
    window['ucp_callback' + _ts] = function(data) {
        _signature = JSON.parse(data);
    }
    var jssdk_ready = false,
        ucp_sign_ready = false;

    var _wx;
    var _init_wx = function(callback, debug) {
        // 注入微信参数
        var wx_config = {
            debug: !!debug, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
            appId: WXCFG.appId, // 公众号的唯一标识
            timestamp: _signature.timestamp, // 必填,生成签名的时间戳
            nonceStr: _signature.nonce, // 必填,生成签名的随机串
            signature: _signature.signature, // 必填,签名,见附录1
            jsApiList: window.WXSDK.config.jsApiList || [ // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
                'onMenuShareTimeline',
                'onMenuShareAppMessage',
                'hideOptionMenu',
                'showOptionMenu',
                'hideOptionMenu',
                'hideMenuItems',
                'showMenuItems',
                'hideAllNonBaseMenuItem',
                'showAllNonBaseMenuItem'
            ]
        };

        // 通过config接口注入权限验证配置
        wx.config(wx_config);

        // 通过error接口处理失败验证
        wx.error(function(res) {
            if (debug) {
                alert('JSSDK接口处理失败验证 ', JSON.parse(res));
            }
        });

        // 通过ready接口处理成功验证的回调
        wx.ready(function() {
            _wx = wx;
            callback & callback();
        });
    };

    // // 分享到朋友圈
    // wx.onMenuShareTimeline({
    //     title: '过来,有个1000万上下的游戏跟你玩一下~',
    //     link: linkUrl,
    //     imgUrl: APP.config.CDN + '/assets/img/tiger/share.jpg',
    //     success: function() {},
    //     cancel: function() {}
    // });

    // // 分享给朋友
    // wx.onMenuShareAppMessage({
    //     title: '过来,有个1000万上下的游戏跟你玩一下~',
    //     desc: '过来,有个1000万上下的游戏跟你玩一下~',
    //     link: linkUrl,
    //     imgUrl: APP.config.CDN + '/assets/img/tiger/share.jpg',
    //     success: function() {},
    //     cancel: function() {}
    // });
    window.WXSDK = {
        config: {
            jsApiList: [ // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
                'onMenuShareTimeline',
                'onMenuShareAppMessage',
                'hideOptionMenu',
                'showOptionMenu',
                'hideOptionMenu',
                'hideMenuItems',
                'showMenuItems',
                'hideAllNonBaseMenuItem',
                'showAllNonBaseMenuItem'
            ]
        },
        init: function(data, callback, debug) {
            callback = callback || function() {}
            debug = debug || _getParameter("wx_debug") == "true";
            try {
                if (debug) console.log("初始化数据", data);
                var cb = function() {
                    if (data) {
                        _wx.onMenuShareTimeline(data);
                        _wx.onMenuShareAppMessage(data);
                        callback & callback(_wx);
                    } else {
                        callback & callback(_wx);
                    }
                }
                if (!_wx) {
                    var _ready = function() {
                        if (debug) console.log("都准备好了");
                        _init_wx(function() {
                            cb();
                        }, debug);
                    }
                    loadscript(_url, function() {
                        if (debug) console.log("获取UCP签名成功", _signature);
                        ucp_sign_ready = true;
                        if (jssdk_ready && ucp_sign_ready) {
                            _ready();
                        }
                    });
                    loadscript(JSSDK_URL, function() {
                        jssdk_ready = true;
                        if (debug) console.log("JSSDK加载成功");
                        if (jssdk_ready && ucp_sign_ready) {
                            _ready();
                        }
                    });
                } else {
                    cb();
                }
            } catch (e) {
                if (debug) console.log(e);
                callback & callback();
            }
        }
    };
    // WXSDK.init({
    //     title: "标题",
    //     desc:"正文",
    //     link: "地址",
    //     imgUrl: "分享图标",
    //     success: function() {
    //         alert(0);
    //     },
    //     cancel: function() {
    //         alert(1);
    //     }
    // },function(wx){
    //     console.log(wx);
    // });
})();

 

 

 

 

分享到:
评论

相关推荐

    微信分享朋友圈PHP实例

    在微信生态系统中,开发者可以利用微信开放平台提供的接口来实现用户在微信朋友圈分享内容的功能。本文将详细讲解如何使用PHP实现微信朋友圈分享的实例,并基于提供的压缩包文件`case`来解析这一过程。 首先,我们...

    微信小程序开发附源码:浅谈微信JS-SDK 微信分享接口开发(介绍版).doc

    这包括设置`debug`模式,填入`appId`、`timestamp`、`nonceStr`、`signature`以及需要调用的API列表,如分享到朋友圈、分享给朋友、分享到QQ和分享到微博的接口。 4. 调用`wx.config()`方法配置微信信息,并在`wx....

    微信--新浪--QQ空间,分享功能

    用户只需轻触分享按钮,即可将这些内容推送到朋友圈、微信群或者个人聊天中。此外,微信还支持第三方应用的分享接口,使得用户可以直接在其他应用中通过微信进行内容分发,极大地拓宽了信息传播的渠道。 新浪,尤其...

    java开发微信分享到朋友圈功能共14页.pdf.zip

    当用户点击朋友圈分享按钮时,会触发预定义的分享内容。 7. **响应式设计**:考虑到不同设备和浏览器的差异,确保分享的图片和内容在各种环境下都能正常显示。这可能需要对CSS和HTML做响应式优化。 8. **错误处理*...

    微信JS-SDK

    2. **分享接口(onMenuShareAppMessage/onMenuShareTimeline)**:这两个接口分别用于设置用户在微信内部分享到朋友和朋友圈的自定义内容。在新版SDK中,需要重新调整这部分代码以适应新的接口规范。 3. **微信登录...

    vue微信分享到朋友圈 vue微信发送给好友

    本文为大家分享了vue微信分享至朋友圈&&分享至朋友代码的封装,供大家参考,具体内容如下 1.新建share.js文件 import {shareSDK} from "../api/common";//分享api import wx from 'weixin-js-sdk' export const ...

    swift-第三方分享微信好友朋友圈新浪微博链接图片音频地址分享

    2. **集成微信朋友圈分享**: - 与微信分享类似,但需创建`WXTimelineShareReq`对象,设置分享内容,然后发送请求。 - 朋友圈分享支持图片、链接、纯文字等类型。 3. **集成新浪微博分享**: - 引入WeiboSDK,并...

    微信内网页开发工具包(微信JS-SDK).mp4.zip

    1. **分享功能**:包括分享到朋友圈、分享给朋友、分享到QQ、分享到微博等,可以自定义分享的内容,如标题、描述、图片等。 2. **支付功能**:集成微信支付接口,实现商品购买或服务付费,提供安全的支付体验。 3. *...

    微信朋友圈分享

    在IT行业中,微信朋友圈分享是一项常见的社交功能,它允许用户将文字、图片、链接等内容发布到自己的微信朋友圈,与好友共享。在这个过程中,通常会涉及到第三方SDK(Software Development Kit)的集成,例如...

    unity 截屏分享微信 QQ等朋友圈

    通常需要指定分享类型(如微信、QQ等)、分享内容(如图片路径、文本描述等)。 5. **处理回调**:SDK通常会提供回调函数,用于接收分享操作的结果。你需要注册这些回调,以便在分享成功或失败时做出相应处理,如...

    Android-Android分享SDK包括微信朋友圈微博QQQQ空间等渠道分享。

    朋友圈分享功能是微信SDK的一部分,允许用户将图文、链接等内容发布到自己的朋友圈。在代码中,你需要创建一个`WXWebpageObject`或`WXImageObject`来包装分享内容,再创建一个`WXMediaMessage`对象,并设置其title、...

    分享到Android微信朋友圈

    在Android平台上,分享内容到微信朋友圈是一项常见的功能。微信提供了开放平台API,使得开发者能够集成这一功能,使得用户可以方便地将自己的应用...理解并掌握这些步骤,就能在你的应用中顺利实现微信朋友圈分享功能。

    Android微信朋友圈分享

    在Android平台上,微信朋友圈分享是移动应用开发中的一个常见需求,它允许用户将应用程序内的内容,如文字、图片、链接等,快速便捷地发布到自己的微信朋友圈。本篇将深入探讨这一功能的实现原理和步骤,同时也会...

    微信分享到朋友圈QQ.rar

    在.NET WebForm框架下开发微信分享到朋友圈的功能是一项常见的需求,尤其对于社交网络与应用程序的交互至关重要。这个名为"微信分享到朋友圈QQ.rar"的压缩包文件,显然包含了一个使用.NET WebForm技术实现的解决方案...

    最新版本微信jdk1.6分享到微信朋友圈 php代码示例

    完成配置后,用户点击分享按钮时,调用`wx.onMenuShareTimeline`和`wx.onMenuShareAppMessage`等接口,设置分享在朋友圈和好友的显示内容。 对于分享到QQ和QQ空间,微信SDK同样提供了相应的接口。你需要额外注册...

    微信分享ASP版

    6. 监听分享事件,如onMenuShareTimeline(分享到朋友圈)和onMenuShareAppMessage(分享给朋友)。 在ASP中实现这些步骤可能需要结合HTTP请求库(如WinHttp.WinHttpRequest.5.1)来发送HTTP请求获取Access Token和...

    微信分享朋友圈多图、文字

    在朋友圈分享文字时,用户可以在输入框中输入想要表达的内容,字数限制通常为200个字符。这部分涉及到文本编辑器的开发,需要确保文字输入的流畅性和格式的正确性,比如换行、特殊字符的支持等。同时,为了防止滥用...

    新浪、腾讯微博,微信好友、朋友圈 分享

    本文将深入探讨如何实现新浪、腾讯微博以及微信的好友和朋友圈的分享功能,无需依赖第三方分享平台。 首先,我们关注的是标题提到的“新浪、腾讯微博,微信好友、朋友圈 分享”。这涉及到了三个主要的社交平台:...

    .net微网页分享到微信朋友圈插件代码(0515).rar

    这个.NET插件的目的是通过后端服务与微信API交互,生成可用于前端展示的分享配置,以便用户在微信内将微网页内容分享到朋友圈。 1. **微信JS-SDK**:这是微信官方提供的JavaScript库,用于在浏览器端实现与微信...

    微信朋友圈拍照和录制视频

    在微信朋友圈中拍照和录制视频是用户日常分享生活点滴的重要方式。这个功能融合了现代智能手机的多媒体技术与社交网络的互动性,使得信息传递更为直观和生动。下面将详细讲解微信朋友圈拍照和录制视频的相关知识点。...

Global site tag (gtag.js) - Google Analytics