微信分享到朋友圈,分享给朋友JS代码

2024-06-04 13:18

本文主要是介绍微信分享到朋友圈,分享给朋友JS代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

php部分
function  jssdk(){
         $appid  '这里替换成你的appid' ;
         $secret  '这里替换成你的key' ;
         $_title  '微信' ;
         $code  $_GET [ 'code' ]; //获取code
         $_SESSION [ 'code' ] =  $code ; //设置code缓存给微信付账使用
         $auth  file_get_contents ( "https://api.weixin.qq.com/sns/oauth2/access_token?appid=" . $appid . "&secret=" . $secret . "&code=" . $code . "&grant_type=authorization_code" );//通过code换取网页授权access_token
         $jsonauth  = json_decode( $auth );  //对JSON格式的字符串进行编码
         $arrayauth  = get_object_vars( $jsonauth ); //转换成数组
         $openid  $arrayauth [ 'openid' ]; //输出openid
         $access_token  $arrayauth [ 'access_token' ];
         $_SESSION [ 'openid' ] =  $openid ;
         
         $accesstoken  file_get_contents ( "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" . $appid . "&secret=" . $secret . "" );//获取access_token
         $token  = json_decode( $accesstoken );  //对JSON格式的字符串进行编码
         $t  = get_object_vars( $token ); //转换成数组
         $access_token  $t [ 'access_token' ]; //输出access_token
         
         $jsapi  file_get_contents ( "https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=" . $access_token . "&type=jsapi" );
         $jsapi  = json_decode( $jsapi );
         $j  = get_object_vars( $jsapi );
         $jsapi  $j [ 'ticket' ]; //get JSAPI
         
         $time  = 14999923234;
         $noncestr $time ;
         $jsapi_ticket $jsapi ;
         $timestamp = $time ;
         $url = 'http://' . $_SERVER [ 'HTTP_HOST' ]. $_SERVER [ 'REQUEST_URI' ];
         $and  "jsapi_ticket=" . $jsapi_ticket . "&noncestr=" . $noncestr . "&timestamp=" . $timestamp . "&url=" . $url . "" ;
         $signature  = sha1( $and );
         return  $signature ;
     }

最后的一句代码,就是说,如果你在输出页面使用<?=jssdk();?>,那么就会输出$signature的内容。其中上面的$time是我手动指定的,这个一定要跟输出页面的js代码的值一样。

输出页面代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
<script type= "text/javascript"  src= "http://res.wx.qq.com/open/js/jweixin-1.0.0.js" ></script>
<script language= "javascript"  type= "text/javascript" >
wx.config({
     debug:  false , //这里是开启测试,如果设置为true,则打开每个步骤,都会有提示,是否成功或者失败
     appId:  '这里换成你的appid' ,
     timestamp:  '14999923234' , //这个一定要与上面的php代码里的一样。
     nonceStr:  '14999923234' , //这个一定要与上面的php代码里的一样。
     signature:  '<?=jssdk();?>' ,
     jsApiList: [
       // 所有要调用的 API 都要加到这个列表中
         'onMenuShareTimeline' ,
         'onMenuShareAppMessage' ,
         'onMenuShareQQ' ,
         'onMenuShareWeibo'
     ]
});
wx.ready( function  () {
     wx.onMenuShareTimeline({
         title:  "<?=$act['act_name']?>" // 分享标题
         link:  "http://www.brandhd.com/v/events/view/<?=$act['act_id']?>" , // 分享链接
         imgUrl:  "http://www.brandhd.com<?=$act['act_poster_small']?>" , // 分享图标
         success:  function  () { 
             // 用户确认分享后执行的回调函数
         },
         cancel:  function  () { 
             // 用户取消分享后执行的回调函数
         }
     });
     wx.onMenuShareAppMessage({
         title:  "<?=$act['act_name']?>" // 分享标题
         desc:  "<?=substr($act['act_stime'],0,10)?><?=$act['act_place']?>" // 分享描述
         link:  "http://www.brandhd.com/v/events/view/<?=$act['act_id']?>" , // 分享链接
         imgUrl:  "http://www.brandhd.com<?=$act['act_poster_small']?>" , // 分享图标
         type:  '' // 分享类型,music、video或link,不填默认为link
         dataUrl:  '' // 如果type是music或video,则要提供数据链接,默认为空
         success:  function  () { 
             // 用户确认分享后执行的回调函数
         },
         cancel:  function  () { 
             // 用户取消分享后执行的回调函数
         }
     });
     wx.onMenuShareQQ({
         title:  "<?=$act['act_name']?>" // 分享标题
         desc:  "<?=substr($act['act_stime'],0,10)?>\n<?=$act['act_place']?>" // 分享描述
         link:  "http://www.brandhd.com/v/events/view/<?=$act['act_id']?>" , // 分享链接
         imgUrl:  "http://www.brandhd.com<?=$act['act_poster_small']?>" , // 分享图标
         success:  function  () { 
            // 用户确认分享后执行的回调函数
         },
         cancel:  function  () { 
            // 用户取消分享后执行的回调函数
         }
     });
     wx.onMenuShareWeibo({
         title:  "<?=$act['act_name']?>" // 分享标题
         desc:  "<?=substr($act['act_stime'],0,10)?>\n<?=$act['act_place']?>" // 分享描述
         link:  "http://www.brandhd.com/v/events/view/<?=$act['act_id']?>" , // 分享链接
         imgUrl:  "http://www.brandhd.com<?=$act['act_poster_small']?>" , // 分享图标
         success:  function  () { 
            // 用户确认分享后执行的回调函数
         },
         cancel:  function  () { 
             // 用户取消分享后执行的回调函数
         }
     });
});
</script>



或者直接输出到php页面
<?php
require_once "jssdk.php";
$jssdk = new JSSDK("wx78437366c2672eb9", "408e952767c07ab8a116751842e57e56");
$signPackage = $jssdk->GetSignPackage();
?>
<html lang="zh_CN">
<body>
</body>
<script>
 $(document).ready(function(){
  /*
   * 注意:
   * 1. 所有的JS接口只能在公众号绑定的域名下调用,公众号开发者需要先登录微信公众平台进入“公众号设置”的“功能设置”里填写“JS接口安全域名”。
   * 2. 如果发现在 Android 不能分享自定义内容,请到官网下载最新的包覆盖安装,Android 自定义分享接口需升级至 6.0.2.58 版本及以上。
   * 3. 常见问题及完整 JS-SDK 文档地址:http://mp.weixin.qq.com/wiki/7/aaa137b55fb2e0456bf8dd9148dd613f.html
   *
   * 开发中遇到问题详见文档“附录5-常见错误及解决办法”解决,如仍未能解决可通过以下渠道反馈:
   * 邮箱地址:weixin-open@qq.com
   * 邮件主题:【微信JS-SDK反馈】具体问题
   * 邮件内容说明:用简明的语言描述问题所在,并交代清楚遇到该问题的场景,可附上截屏图片,微信团队会尽快处理你的反馈。
   */
   //alert($.cookie('user_id'));
    var links1='http://mm.gushen178.com/wapZhuanti';
    if($.cookie('user_id')!=undefined||$.cookie('user_id')!=null){
links1='http://mm.gushen178.com/wapZhuanti/?rec_uid='+$.cookie("uid");
}
//alert(links1);

   wx.ready(function () {
wx.onMenuShareTimeline({
title: '150万现金奖励是真的么?别逗了!你看看有多少大学生已经拿奖了!',
desc: '2016“股神交友”中国大学生模拟证券投资大奖赛,总冠军8万元,月冠军1万元,周冠军3千元。每周每月每年前三名都有奖!',
link:links1,
imgUrl:'http://mm.gushen178.com/wapZhuanti/images/512.png',
success: function () {
alert('已分享');
},
cancel: function () { 
alert('已取消');
}
});
wx.onMenuShareAppMessage({
title: '150万现金奖励是真的么?别逗了!你看看有多少大学生已经拿奖了!',
desc: '2016“股神交友”中国大学生模拟证券投资大奖赛,总冠军8万元,月冠军1万元,周冠军3千元。每周每月每年前三名都有奖!',
link: links1,
imgUrl:'http://mm.gushen178.com/wapZhuanti/images/512.png',
type: '', // 分享类型,music、video或link,不填默认为link
dataUrl: '', // 如果type是music或video,则要提供数据链接,默认为空
success: function () {
alert('已分享');
},
cancel: function () { 
alert('已取消');
}
});
   });
 });
</script>
<script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>
<script>
 $(document).ready(function(){
  /*
   * 注意:
   * 1. 所有的JS接口只能在公众号绑定的域名下调用,公众号开发者需要先登录微信公众平台进入“公众号设置”的“功能设置”里填写“JS接口安全域名”。
   * 2. 如果发现在 Android 不能分享自定义内容,请到官网下载最新的包覆盖安装,Android 自定义分享接口需升级至 6.0.2.58 版本及以上。
   * 3. 常见问题及完整 JS-SDK 文档地址:http://mp.weixin.qq.com/wiki/7/aaa137b55fb2e0456bf8dd9148dd613f.html
   *
   * 开发中遇到问题详见文档“附录5-常见错误及解决办法”解决,如仍未能解决可通过以下渠道反馈:
   * 邮箱地址:weixin-open@qq.com
   * 邮件主题:【微信JS-SDK反馈】具体问题
   * 邮件内容说明:用简明的语言描述问题所在,并交代清楚遇到该问题的场景,可附上截屏图片,微信团队会尽快处理你的反馈。
   */
  wx.config({
    debug: false,
    appId: '<?php echo $signPackage["appId"];?>',
    timestamp: <?php echo $signPackage["timestamp"];?>,
    nonceStr: '<?php echo $signPackage["nonceStr"];?>',
    signature: '<?php echo $signPackage["signature"];?>',
    jsApiList: ["onMenuShareTimeline","onMenuShareAppMessage","onMenuShareQQ","onMenuShareWeibo","onMenuShareQZone","startRecord","stopRecord","onVoiceRecordEnd","playVoice","pauseVoice","stopVoice","onVoicePlayEnd","uploadVoice","downloadVoice","chooseImage","previewImage","uploadImage","downloadImage","translateVoice","getNetworkType","openLocation","getLocation","hideOptionMenu","showOptionMenu","hideMenuItems","showMenuItems","hideAllNonBaseMenuItem","showAllNonBaseMenuItem","closeWindow","scanQRCode","chooseWXPay","openProductSpecificView"]


  });
 });
</script>
</html>

这篇关于微信分享到朋友圈,分享给朋友JS代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1030185

相关文章

问题:第一次世界大战的起止时间是 #其他#学习方法#微信

问题:第一次世界大战的起止时间是 A.1913 ~1918 年 B.1913 ~1918 年 C.1914 ~1918 年 D.1914 ~1919 年 参考答案如图所示

[职场] 护理专业简历怎么写 #经验分享#微信

护理专业简历怎么写   很多想成为一名护理方面的从业者,但是又不知道应该怎么制作一份简历,现在这里分享了一份护理方面的简历模板供大家参考。   蓝山山   年龄:24   号码:12345678910   地址:上海市 邮箱:jianli@jianli.com   教育背景   时间:2011-09到2015-06   学校:蓝山大学   专业:护理学   学历:本科

大学湖北中医药大学法医学试题及答案,分享几个实用搜题和学习工具 #微信#学习方法#职场发展

今天分享拥有拍照搜题、文字搜题、语音搜题、多重搜题等搜题模式,可以快速查找问题解析,加深对题目答案的理解。 1.快练题 这是一个网站 找题的网站海量题库,在线搜题,快速刷题~为您提供百万优质题库,直接搜索题库名称,支持多种刷题模式:顺序练习、语音听题、本地搜题、顺序阅读、模拟考试、组卷考试、赶快下载吧! 2.彩虹搜题 这是个老公众号了 支持手写输入,截图搜题,详细步骤,解题必备

uniapp接入微信小程序原生代码配置方案(优化版)

uniapp项目需要把微信小程序原生语法的功能代码嵌套过来,无需把原生代码转换为uniapp,可以配置拷贝的方式集成过来 1、拷贝代码包到src目录 2、vue.config.js中配置原生代码包直接拷贝到编译目录中 3、pages.json中配置分包目录,原生入口组件的路径 4、manifest.json中配置分包,使用原生组件 5、需要把原生代码包里的页面修改成组件的方

公共筛选组件(二次封装antd)支持代码提示

如果项目是基于antd组件库为基础搭建,可使用此公共筛选组件 使用到的库 npm i antdnpm i lodash-esnpm i @types/lodash-es -D /components/CommonSearch index.tsx import React from 'react';import { Button, Card, Form } from 'antd'

17.用300行代码手写初体验Spring V1.0版本

1.1.课程目标 1、了解看源码最有效的方式,先猜测后验证,不要一开始就去调试代码。 2、浓缩就是精华,用 300行最简洁的代码 提炼Spring的基本设计思想。 3、掌握Spring框架的基本脉络。 1.2.内容定位 1、 具有1年以上的SpringMVC使用经验。 2、 希望深入了解Spring源码的人群,对 Spring有一个整体的宏观感受。 3、 全程手写实现SpringM

[职场] 公务员的利弊分析 #知识分享#经验分享#其他

公务员的利弊分析     公务员作为一种稳定的职业选择,一直备受人们的关注。然而,就像任何其他职业一样,公务员职位也有其利与弊。本文将对公务员的利弊进行分析,帮助读者更好地了解这一职业的特点。 利: 1. 稳定的职业:公务员职位通常具有较高的稳定性,一旦进入公务员队伍,往往可以享受到稳定的工作环境和薪资待遇。这对于那些追求稳定的人来说,是一个很大的优势。 2. 薪资福利优厚:公务员的薪资和

我似乎与您成了无话不谈的好朋友

穿越太空的玩耍 今天的穿越太空的玩耍,老师,仔细地在羽毛上涂涂画画,造飞机,他也总爱和孩子们说,唱完后,我似乎与您成了无话不谈的好朋友,工程师,玩耍该车既能像普通汽车一样在路上行驶。 造轮船,鸟王又说,买了一盒36色的玩耍水彩笔,洒向艳羽鸟,说,一看到它,想到很多很多-吧嗒,时间过得真快,六年前。 百灵鸟抹上了亮晶晶的指甲油这时,哇,汽车上有很多按钮琳琅满目,让我们都能到太空旅游,刚刚我在

代码随想录算法训练营:12/60

非科班学习算法day12 | LeetCode150:逆波兰表达式 ,Leetcode239: 滑动窗口最大值  目录 介绍 一、基础概念补充: 1.c++字符串转为数字 1. std::stoi, std::stol, std::stoll, std::stoul, std::stoull(最常用) 2. std::stringstream 3. std::atoi, std

android一键分享功能部分实现

为什么叫做部分实现呢,其实是我只实现一部分的分享。如新浪微博,那还有没去实现的是微信分享。还有一部分奇怪的问题:我QQ分享跟QQ空间的分享功能,我都没配置key那些都是原本集成就有的key也可以实现分享,谁清楚的麻烦详解下。 实现分享功能我们可以去www.mob.com这个网站集成。免费的,而且还有短信验证功能。等这分享研究完后就研究下短信验证功能。 开始实现步骤(新浪分享,以下是本人自己实现