微信公众平台开发配置及自定义分享

刚刚做了微信的自定义分享,折腾了好一会,完了记个笔记。
微信JS-SKD说明文档
本次测试需要:通过ICP备案的域名已认证的微信公众号

配置篇

1.设置》公众号设置》功能设置》JS接口安全域名

直接将域名填写进入就好,可以是yeli.studio ,也可以是abc.yeli.studio。此时是无法保存的,需要将MP_verify_XWsldS5dzRvbRcvT.txt下载下来拷贝到域名根目录下面,待会点击保存的时候,微信会通过链接:abc.yeli.studio/MP_verify_XWsldS5dzRvbRcvT.txt来验证是否可以访问。
补充:
test_nginx.conf

server {
        # the port your site will be served on
        listen      80;
        # the domain name it will serve for
        server_name abc.yeli.studio; # substitute your machine's IP address or FQDN
        charset     utf-8;

        # max upload size
        client_max_body_size 75M;   # adjust to taste

        # Django media
        location /media  {
            alias /root/application_all/media;  # your Django project's media files - amend as required
        }

        location /static {
            alias /root/application_all/static; # your Django project's static files - amend as required
        }

        # Finally, send all non-media requests to the Django server.
        location / {
            uwsgi_pass  unix:///root/application_all/project/register_site/activity.sock; # for a file socket
            include     /root/application_all/project/register_site/uwsgi_params; # the uwsgi_params file you installed
        }

    }

像这样的nginx配置根目录是没有对应的文件夹的,它直接对接到了程序应用。
此种情况可以在程序应用里面增加一个url路由,我使用Django,那么就是这样:
1.在urls.py中添加一个路由

urlpatterns = [
    ...
    url(r'MP_verify_XWsldS5dzRvbRcvT.txt',views.getMP_varify),
    ...
]

2.在views.py 中返回此文本MP_verify_XWsldS5dzRvbRcvT.txt中的字符串

def getMP_varify(request):
    return HttpResponse ("XWsldS5dzRvbRcvT")

点击保存,成功

设置域名

2.开发》基本配置

启用开发者,获得AppID、AppSecret两个参数
然后填写IP白名单,也就是你服务器所在的公网ip


启用开发者/设置IP白名单

服务端篇

由前端发送ajax到服务端获取,前端需要抓去当前页面url提交给服务端。
服务端的工作如下:
获取token:https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={appid}&secret={secret}
通过token获取ticket:https://api.weixin.qq.com/cgi-bin/ticket/getticket?type=jsapi&access_token={token}
相关参数生成:
利用下面微信提供的sign.py文件,传入ticket和页面url即可。
http://demo.open.weixin.qq.com/jssdk/sample.zip
备注:链接中包含php、java、nodejs以及python的示例代码供第三方参考,第三方切记要对获取的accesstoken以及jsapi_ticket进行缓存以确保不会触发频率限制。
服务端返回json样例:

{
  appId:"wxb6d7b7803694fc83"
  jsapi_ticket:"kgt8ON7yVITDhtdwci0qeSFCSQshWFBoH3E_uwLdKTAex6sBMGa0x7Jk_-09rdTaErwM475Y1ScmIZkNcFeWNQ"
  nonceStr:"6WPMJHSpBzWLO0p"
  signature:"1fb234358370736216c1f76badb489fa1100e92d"
  timestamp:1505206494
  url:"http://abc.yeli.studio/"
}

至此,服务端的工作就完了

前端篇

在需要分享的页面中引入两个js文件
http://res.wx.qq.com/open/js/jweixin-1.2.0.js
wexin.js,wexin.js内容如下:

$.ajax({
   url:'http://abc.yeli.studio/get_wexin_params',
   type:'post',
   data:{
       "share_url":window.location.href.split('#')[0],
       "csrfmiddlewaretoken":$("input[name='csrfmiddlewaretoken']").val()
   },
   success:function(_data){
        wx.config({
            debug: false,
            appId: 'wxb6d7b7803694fc83', 
            timestamp: _data.timestamp, 
            nonceStr: _data.nonceStr, 
            signature: _data.signature,
            jsApiList: ["onMenuShareTimeline","onMenuShareAppMessage","onMenuShareQZone","onMenuShareQQ"] 
        });
        wx.ready(function () {

          var title='我是标题'
          var desc='我是描述内容'
          var link='http://abc.yeli.studio/' // 分享链接,该链接必须在公众号JS安全域名之下,`http://abc.yeli.studio/another_page`也是可以的
          var imageUrl='http://abc.yeli.studio/media/QQ20170911-150722copy.png'
              //分享到消息
          wx.onMenuShareAppMessage({
             title: title,
             desc: desc, 
             link: link,
             imgUrl: imageUrl,
             type: '', // 分享类型,music、video或link,不填默认为link
             dataUrl: '', // 如果type是music或video,则要提供数据链接,默认为空
             success: function () {
                 //分享成功
              },
             cancel: function () {
              // 取消分享
              }
          })
              //分享到朋友圈
          wx.onMenuShareTimeline({
            title: title, // 分享标题
            link: link, // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致
            imgUrl: imageUrl, // 分享图标
            success: function () {
              // 分享成功
             },
            cancel: function () {
              // 取消分享
             }
          })
        })
     }
})

至此,网页的自定义内容分享完成。


我的博客 http://blog.xander-ye.com

微信公众号

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容