这篇文章主要介绍PHP实现微信分享朋友圈demo源码,感兴趣的朋友参考下。

1、先加载微信自带的接口代码<?php

class JSSDK {

private $appId;

private $appSecret;

public function __construct($appId, $appSecret) {

$this->appId = $appId;

$this->appSecret = $appSecret;

}

public function getSignPackage() {

$jsapiTicket = $this->getJsApiTicket();

// 注意 URL 一定要动态获取,不能 hardcode.

$protocol = (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off' || $_SERVER['SERVER_PORT'] == 443) ? "https://" : "http://";

$url = "$protocol$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";

$timestamp = time();

$nonceStr = $this->createNonceStr();

// 这里参数的顺序要按照 key 值 ASCII 码升序排序

$string = "jsapi_ticket=$jsapiTicket&noncestr=$nonceStr&timestamp=$timestamp&url=$url";

$signature = sha1($string);

$signPackage = array(

"appId" => $this->appId,

"nonceStr" => $nonceStr,

"timestamp" => $timestamp,

"url" => $url,

"signature" => $signature,

"rawString" => $string

);

return $signPackage;

}

private 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;

}

private function getJsApiTicket() {

// jsapi_ticket 应该全局存储与更新,以下代码以写入到文件中做示例

$data = json_decode($this->get_php_file("jsapi_ticket.php"));

if ($data->expire_time < time()) {

$accessToken = $this->getAccessToken();

// 如果是企业号用以下 URL 获取 ticket

// $url = "https://qyapi.weixin.qq.com/cgi-bin/get_jsapi_ticket?access_token=$accessToken";

$url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?type=jsapi&access_token=$accessToken";

$res = json_decode($this->httpGet($url));

$ticket = $res->ticket;

if ($ticket) {

$data->expire_time = time() + 7000;

$data->jsapi_ticket = $ticket;

$this->set_php_file("jsapi_ticket.php", json_encode($data));

}

} else {

$ticket = $data->jsapi_ticket;

}

return $ticket;

}

private function getAccessToken() {

// access_token 应该全局存储与更新,以下代码以写入到文件中做示例

$data = json_decode($this->get_php_file("access_token.php"));

if ($data->expire_time < time()) {

// 如果是企业号用以下URL获取access_token

// $url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=$this->appId&corpsecret=$this->appSecret";

$url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$this->appId&secret=$this->appSecret";

$res = json_decode($this->httpGet($url));

$access_token = $res->access_token;

if ($access_token) {

$data->expire_time = time() + 7000;

$data->access_token = $access_token;

$this->set_php_file("access_token.php", json_encode($data));

}

} else {

$access_token = $data->access_token;

}

return $access_token;

}

private function httpGet($url) {

$curl = curl_init();

curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);

curl_setopt($curl, CURLOPT_TIMEOUT, 500);

// 为保证第三方服务器与微信服务器之间数据传输的安全性,所有微信接口采用https方式调用,必须使用下面2行代码打开ssl安全校验。

// 如果在部署过程中代码在此处验证失败,请到 http://curl.haxx.se/ca/cacert.pem 下载新的证书判别文件。

curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, true);

curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, true);

curl_setopt($curl, CURLOPT_URL, $url);

$res = curl_exec($curl);

curl_close($curl);

return $res;

}

private function get_php_file($filename) {

return trim(substr(file_get_contents($filename), 15));

}

private function set_php_file($filename, $content) {

$fp = fopen($filename, "w");

fwrite($fp, "<?php exit();?>" . $content);

fclose($fp);

}

}

2、修改自己的配制信息用微信浏览器打开就可以了<?php

require_once "jssdk.php";

$appid = 'wx110';

$APPSECRET = '110';

$jssdk = new JSSDK($appid, $APPSECRET);

$signPackage = $jssdk->GetSignPackage();

?>

js微信自定义分享标题、链接和图标

/*

* 注意:

* 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 $appid; ?>',

timestamp: <?php echo $signPackage["timestamp"]; ?>,

nonceStr: '<?php echo $signPackage["nonceStr"]; ?>',

signature: '<?php echo $signPackage["signature"]; ?>',

jsApiList: [

'onMenuShareTimeline'

]

});

wx.ready(function() {

wx.onMenuShareTimeline({

title: '二当家的', // 分享标题

link: 'http://www.erdangjiade.com/', // 分享链接

imgUrl: '', // 分享图标

success: function() {

// 用户确认分享后执行的回调函数

},

cancel: function() {

// 用户取消分享后执行的回调函数

}

});

});

请用微信浏览器打开,并打开右上方按钮。分享到朋友圈试试。

相关推荐:

php网站做分享到朋友圈,PHP实现微信分享朋友圈相关推荐

  1. 一键清空朋友圈软件_微信清理朋友圈app下载-微信清理朋友圈下载v1.8.0 安卓版-西西软件下载...

    微信清理朋友圈app一款强大的微信清理工具,当你想要重置自己的微信号并删除所有的内容之时,又觉得一条条删太麻烦了,就可以用到这款神器工具,可以帮助你一键删除掉朋友圈内的所有内容,帮助你轻松的重置微信号 ...

  2. 微信h5实现分享给朋友url改变_h5 微信分享朋友和朋友圈

    生成JS-SDK权限验证签名 实现发送给朋友和分享到朋友圈时内容参数自定义 一.微信JS-SDK 1. 获得Access Token access token的获得方法在前面有介绍,详情见 微信公众平 ...

  3. android微信朋友圈开发,Android微信、朋友圈分享

    [实例简介] Android调用微信包实现微信.朋友圈分享.并能够获取分享的结果.收到毁掉消息 [实例截图] [核心代码] WeChatShare └── TestWXShare ├── Androi ...

  4. 前端做微信好友分享_一篇搞定微信分享和line分享

    前言 在h5的页面开发中,分享是不可或缺的一部分,对于一些传播性比较强的页面,活动页之类的,分享功能极为重要.例如,京东等电商年末时会有一系列的总结h5在微信中传播,就不得不提到微信的分享机制. 微信 ...

  5. php 微信分享链接怎么弄,PHP实现 微信--分享朋友链接

    不是些高深知识,但是第一次做,确实费了很多的时间.终于一点一点的扣了出来. 目前已经使用中. 解决这个问题,总共碰到了几次BUG,1是生成的签名不对,自己打印出来,在去微信的签名算法页面一一核对.这时 ...

  6. php微信分享带缩略图,静态页面实现微信分享带缩略图、标题和描述

    在前一篇文章<微信转发或分享朋友圈带缩略图.标题和描述的实现方法>中,余斗已经教大家如何实现在自有网站上实现微信分享后自带缩略图.标题和描述,这里是在动态php页面中实现,这里有很大的局限 ...

  7. android 微信分享多张图片大小,Android 关于微信分享图片过大失败的解决方案

    android 关于微信分享图片过大失败的解决方案.这是因为微信对缩略图做了限制,最大不超过32k. 所以可以先通过图片加载工具获取bitmap,然后进行压缩,压缩方法如下: //压缩图片 publi ...

  8. vue 如何调用微信分享_Vue项目通过JSSDK调用微信分享接口

    最近在做一个公司微信分享项目的功能,毕竟第一次做,对于小白也是个挑战,特此记录一下自己的开发过程,以便以后查阅.(转载请标明出处,码字好辛苦的qaq) 使用步骤: 1.绑定域名: 一开始当然是去查微信 ...

  9. vue项目全局配置微信分享_Vue项目history模式下微信分享总结-个人文章-SegmentFault思否...

    每回遇到微信分享都是一个坑,目前的商城项目使用vue开发,采用history的路由模式,配置微信分享又遇到了很多问题,最后终于解决了,现将解决的过程分享一下. 原文https://justyeh.to ...

  10. uni-app - H5 公众号网页分享到微信朋友圈 / 转发分享给朋友好友 / 分享到手机 QQ / 分享到 QQ 空间,给微信分享卡片设置图标、标题、描述文字等(JS-SDK 通用解决方案放心用)

    前言 如果您是纯 Vue.js 项目(或 Nuxt.js),请访问 Vue - 最新网页 H5 分享到微信朋友圈 / 转发分享好友 这篇详细教程. 目前网上大部分教程都过时了(老版本.无效),并且未对 ...

最新文章

  1. 为给微芯片拍照,IBM小哥用乐高拼了个电动显微镜,搭载树莓派,360度无死角拍摄...
  2. angular2初入眼帘之-搭个环境
  3. linux消息信号丢失,Linux信号丢失问题分析
  4. jenkins+maven+ansible实现测试环境完全自动发布
  5. python 打包 无需安装运行环境_无需Python环境,小白也可以运行的抢票程序
  6. 分布式计算—MapReduce、Spark、Storm、Flink分别适用什么场景
  7. Java中间件:淘宝网系统高性能利器
  8. python绘制数字23_Python 画数码数字8
  9. C++为什么空格无法输出_OOP 面向对象编程:由 C 到 C++
  10. 尤其适合程序员使用的TextMate for Mac
  11. juqery-筛选器-找前后上下
  12. eslint的安装与使用
  13. 人人网,微博,QQ空间,朋友圈,常用API调用实现方法
  14. AD19无法生成PCB_PCB制造拥抱AI
  15. kafka 查看队列信息
  16. matlab pr曲线实例,再理解下ROC曲线和PR曲线 | 丕子
  17. Qt——原地奔跑的小人
  18. 网易免费邮箱服务器,网易免费邮箱重新免费开放POP3/SMTP服务
  19. 酷睿i7 1260p怎么样 i71260p参数
  20. 在电梯里你的一举一动

热门文章

  1. sqlite附加数据库操作实例
  2. 杂谈:加班中离世的人
  3. Eclipse-WTP什么意思?
  4. eclipse 安装jetty WTP Adaptor插件
  5. 计算机画图调整画笔粗细,【2人回答】画图里画笔怎么加粗-3D溜溜网
  6. wireshark如何抓取本机包
  7. h5 字体加粗_HTML中如何将字体加粗
  8. html图片排版技巧,【CSS技巧】多图片的垂直居中排版
  9. mysql知识系列:报错right syntax to use near IDENTIFIED BY
  10. Rust学习教程30 - Panic原理剖析