JS中静态页面实现微信分享功能

微信分享网页的时候,希望分享出来的链接是标题+描述+缩略图,微信开发代码示例里已提供了方法,但只适用于动态页面。我使用phpcms把页面生成了静态文件,示例代码就起不到作用了。在网上找了下,有大神使用ajax实现静态页面也能实现微信分享功能,在这里分享给大家。

前台代码:

?
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
<script>
url=location.href;
  $.ajax({
  type : "get" ,
  url : "http://xxxxxxxxx/jssdk.php?url=" +url,//替换网址,xxx根据自己jssdk文件位置修改
  dataType : "jsonp" ,
  jsonp: "callback" ,
  jsonpCallback: "success_jsonpCallback" ,
  success : function (data){
   wx.config({
appId: data.appId,
timestamp: data.timestamp,
nonceStr: data.nonceStr,
signature: data.signature,
jsApiList: [
   "onMenuShareTimeline" , //分享给好友
   "onMenuShareAppMessage" , //分享到朋友圈
   "onMenuShareQQ" , //分享到QQ
   "onMenuShareWeibo" //分享到微博
]
});
},
     error: function (data){
      alert( "连接失败!" );
     }
});
  wx.ready( function (){
  var shareData = {
  title: '标题' ,
  desc: '简介' , //这里请特别注意是要去除html
  link: '链接' ,
  imgUrl: '题图'
  };
  wx.onMenuShareAppMessage(shareData);
  wx.onMenuShareTimeline(shareData);
  wx.onMenuShareQQ(shareData);
  wx.onMenuShareWeibo(shareData);
  });
</script>

记得把jquery的库也加上去,否则ajax不会运行

修改服务端文件jssdk.PHP

?
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
<?php
$url = $_GET [ 'url' ];
class JSSDK {
  private $appId ;
  private $appSecret ;
  private $url ;
  public function __construct( $appId , $appSecret , $url ) {
  $this ->appId = $appId ;
  $this ->appSecret = $appSecret ;
$this ->url = $url ;
  }
  public function getSignPackage() {
  $jsapiTicket = $this ->getJsApiTicket();
  $protocol = (! empty ( $_SERVER [ 'HTTPS' ]) && $_SERVER [ 'HTTPS' ] !== 'off' || $_SERVER [ 'SERVER_PORT' ] == 443) ? "https://" : "http://" ;
  // $url = "$protocol$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";
$url = $this ->url;
  $timestamp = time();
  $nonceStr = $this ->createNonceStr();
  // 这里参数的顺序要按照 key 值 ASCII 码升序排序
  $string = "jsapi_ticket=$jsapiTicket&noncestr=$nonceStr×tamp=$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( file_get_contents ( "jsapi_ticket.json" ));
  if ( $data ->expire_time < time()) {
   $accessToken = $this ->getAccessToken();
   // 如果是企业号用以下 URL 获取 ticket
   $res = json_decode( $this ->httpGet( $url ));
   $ticket = $res ->ticket;
   if ( $ticket ) {
   $data ->expire_time = time() + 7000;
   $data ->jsapi_ticket = $ticket ;
   $fp = fopen ( "jsapi_ticket.json" , "w" );
   fwrite( $fp , json_encode( $data ));
   fclose( $fp );
   }
  } else {
   $ticket = $data ->jsapi_ticket;
  }
  return $ticket ;
  }
  private function getAccessToken() {
  // access_token 应该全局存储与更新,以下代码以写入到文件中做示例
  $data = json_decode( file_get_contents ( "access_token.json" ));
  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 ;
   $fp = fopen ( "access_token.json" , "w" );
   fwrite( $fp , json_encode( $data ));
   fclose( $fp );
   }
  } 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);
  curl_setopt( $curl , CURLOPT_SSL_VERIFYPEER, false);
  curl_setopt( $curl , CURLOPT_SSL_VERIFYHOST, false);
  curl_setopt( $curl , CURLOPT_URL, $url );
  $res = curl_exec( $curl );
  curl_close( $curl );
  return $res ;
  }
}
$jssdk = new JSSDK( "公众号ID" , "公众号密钥" , $url ); //按照自己的公众号填写
$signPackage = $jssdk ->GetSignPackage();
$tmp =json_encode( array ( 'appId' => $signPackage [ "appId" ], 'timestamp' => $signPackage [ "timestamp" ], 'nonceStr' => $signPackage [ "nonceStr" ], 'signature' => $signPackage [ "signature" ], 'url' => $signPackage [ "url" ]));
$callback = $_GET [ 'callback' ];
echo $callback . '(' . $tmp . ')' ;
exit ;
?>
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值