微信JSSDK接入问题记录及源码

今天应客户要求,把一个html5游戏的微信分享功能从第三方库切换到官方库了,官方微信JSSDK

这其中碰到了一些问题,记录一下(服务端环境为PHP):

1. 开启openssl功能

Warning: file_get_contents(https://graph.qq.com/user/xxxxx) [function.file-get-contents]: failed to open stream: No error in /xxx/php.php on line 2

遇到这样的错误的,是因为没有开启openssl功能,可以在php.ini中把 extension=php_openssl.dll之前的;去掉,保存并重启(最好重启服务器)

注意:php.ini的位置是在phpinfo中找的。

2. encodeURIComponent(url)

js端的要记得把当前页面的url编码,不然送给服务器的参数可能不对,最后导致签名出错。

最后附上相关的源码,包括服务端和javascript:

  • 客户端javascript
/**
 * Author: lonewolf
 * Date: 2015-02-08 13:48:43
 */
// 微信分享的数据
var wxData = {
    title : ‘好玩的游戏!‘,
    desc : ‘大家快来玩!‘,
    link : ‘http://xxx‘,
    imgUrl : ‘http://xxx.png‘,
    type: ‘‘,
    dataUrl: ‘‘,
    success: function () {
        //分享成功
       //do something!
    }
};
// 配置数据
wxConfigData={
    debug: true, //调试的时候最好设为true,它每一步都会alert数据出来,让你知道出了什么问题
    appId: ‘xxx‘,
    timestamp: 1423367602, //随便填写一串数字
    nonceStr: ‘sMADlDUaGt6DsEc6‘, //随便一字符串
    signature: ‘‘, //**这个要到服务器获取**
    jsApiList: [ //用到的功能,自定义
    ‘checkJsApi‘,
    ‘onMenuShareTimeline‘,
    ‘onMenuShareAppMessage‘,
    ‘onMenuShareQQ‘,
    ‘onMenuShareWeibo‘
    ]
}
// 获取签名
function wxGetSign () {
    var data1={};
    data1["timestamp"]=wxConfigData["timestamp"];
    data1["nonceStr"]=wxConfigData["nonceStr"];
    data1["url"]=encodeURIComponent(location.href.split(‘#‘)[0]);
    // alert(data1["url"]);
    // 自己找个ajax库
    ajax.post("wxGetSign.php?ran="+Math.random(), data1, function (data) {
        // 返回{sign:xxx}
        // alert(data);
        data=eval("("+data+")");
        if(data["sign"])
        {
            // 获取签名成功,初始化分享
            wxConfigData["signature"]=data["sign"];
            wxInit();
        }
    });
}
// 初始化,已经获得签名
function wxInit () {
    // 配置参数
    wx.config(wxConfigData);
    // 分享
    wx.ready(function(){
        addWeixinShareListening();
    });
    wx.error(function(res){
        // alert(res);
    });
}
// 分享绑定
function addWeixinShareListening () {
    wx.onMenuShareTimeline(wxData);
    wx.onMenuShareAppMessage(wxData);
    wx.onMenuShareQQ(wxData);
    wx.onMenuShareWeibo(wxData);
}

//执行,获取签名
wxGetSign();

相关的参数改一改,放到页面中就可以了,也可保存为一个js文件。

  • 服务端
<?php
/*
因为获取的access_token以及jsapi_ticket都有时间限制(7200秒后失效),且调用接口的次数有限制,所以我们得把得到的access_token和jsapi_ticket缓存到一个文件里,每次请求都检查是否已过期。
*/

//设置时区
date_default_timezone_set(‘Asia/ShangHai‘);
//session
session_start();
$returnObj = array("sign" => "");
// 常量
$appId="xxx";
$appSecret="xxx";

$timestamp = $_POST["timestamp"];
$nonceStr = $_POST["nonceStr"];
$url = $_POST["url"];

if ($timestamp&&$nonceStr&&$url) {
    // 获取access_token和jsapi_ticket
    $access_token="";
    $jsapi_ticket="";
    // 保存到文件sign.txt
    $filename="sign.txt";
    $time=time();
    // 先查找本地有没有保存
    if (file_exists($filename)) {
        $str=file_get_contents($filename);
        $obj=json_decode($str,true);
        if ($obj&&$obj["access_token"]&&$obj["jsapi_ticket"]&&$obj["time"]) {
            $lastTime=intval($obj["time"]);
            // 标准的是7200,要少一点
            if ($time-$lastTime<7100) {
                $access_token=$obj["access_token"];
                $jsapi_ticket=$obj["jsapi_ticket"];
            }
        }
    }
    if ($access_token=="") {
        // 如果第一次或已过期则重新获取
        $returnObj["re"]=1; //这个只是测试用,看看是不是新请求
        // 获取access_token
        $tokenUrl="https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={$appId}&secret={$appSecret}";
        $str=file_get_contents($tokenUrl);
        // $returnObj["token_data"]=$str;
        $obj=json_decode($str,true);
        if ($obj&&$obj["access_token"]) {
            $access_token=$obj["access_token"];
            // 获取jsapi_ticket
            $ticketUrl="https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token={$access_token}&type=jsapi";
            $str=file_get_contents($ticketUrl);
            // $returnObj["ticket_data"]=$str;
            $obj=json_decode($str,true);
            if ($obj&&$obj["errcode"]==0&&$obj["ticket"]) {
                $jsapi_ticket=$obj["ticket"];
                // 保存文件
                $data=array("access_token"=>$access_token,"jsapi_ticket"=>$jsapi_ticket,"time"=>$time);
                $data=json_encode($data);
                file_put_contents($filename, $data);
            }
            else
            {
                $returnObj["error"]="wrong ticket";
            }
        }
        else
        {
            $returnObj["error"]="wrong access_token";
        }
    }
    if ($access_token&&$jsapi_ticket) {
        // test
        // $returnObj["access_token"]=$access_token;
        // $returnObj["jsapi_ticket"]=$jsapi_ticket;
        // 签名算法
        $str="jsapi_ticket={$jsapi_ticket}&noncestr={$nonceStr}&timestamp={$timestamp}&url={$url}";
        // $returnObj["signstr"]=$str;
        $sign=sha1($str);
        $returnObj["sign"]=$sign;
    }
}
echo json_encode($returnObj);
?>

至此,整个过程就算完了。

时间: 2025-01-04 16:24:48

微信JSSDK接入问题记录及源码的相关文章

Andriod项目实战——如何在微信H5棋牌斗牛房卡源码平台租售搭建中的一个包下建新包教程

最开始是想将各个类分门别类地微信H5棋牌斗牛房卡源码平台租售搭网址:h5.fanshubbs.com联系Q1687054422存放在不同的包中,所以想在项目源码包中新建几个不同功能的包eg:utils.model.receiver等,最后的结果应该是下图左边这样的: 很明显建立项目后的架构是上图右边这样的,所以后面理所当然地选择new-->package,name栏填上activity,然而结果是下面左边这样的... 这样的结果明显与预想的不一样,我们看到activity与com.mukekew

2018新版微信极速赛车飞艇8合一源码下载搭建

2018新版微信极速赛车飞艇8合一源码下载搭建教程:http://fanshubbs.com/thread-255-1-1.html 参考搭建源码项目 <微信公众号北京赛车PK10源码下载> 示例代码 C++ #include "hpsocket/HPSocket.h" /* Listener Class */ class CListenerImpl : public CTcpPullServerListener { public: // 5. process networ

优化Recorder H5录音:可边录边转码上传服务器,支持微信提供Android IOS Hybrid App源码

目录 一.Recorder H5录音库的特性 (1)浏览器支持 (2)功能支持 二.使用预览截图 (1)移动端H5 (2)IOS Hybrid App (3)Android Hybrid App 三.应用场景 四.优化过程记录 (1)为什么要升级优化 (2)开始使用Web Worker加速转码 (3)剩下的问题 五.Hybrid App存在的意义 六.更多支持 Recorder H5 GitHub开源库随着支持功能的增多,音频转码处理效率渐渐的跟不上需求了,近期抽时间对音频转码部分进行了升级优化

C#/ASP.NET MVC微信公众号接口开发之从零开发(二) 接收微信消息并且解析XML(附源码)

文章导读: C#微信公众号接口开发之从零开发(一) 接入微信公众平台 微信接入之后,微信通过我们接入的地址进行通信,其中的原理是微信用户发送消息给微信公众账号,微信服务器将消息以xml的形式发送到我们的绑定的地址上,通过解析XML数据,获取到微信用户发送的消息,让根据微信消息(文本:关键字,图片,语音等等)回复XML格式的数据给微信服务器,微信服务器再将接收到的消息返回给用户微信. 我们所需要做的:接收消息和返回消息 一.创建实体类 首先看文档http://mp.weixin.qq.com/wi

微信聊天记录查看器(程序+源码) - iOS版

本文版权归cxun所有,如有转载请注明出处与本文链接,谢谢!原文地址:http://www.cnblogs.com/cxun/p/4338643.html 摘要 iPhone中的微信是不是占用了越来越多的空间呢?不想删图片?不舍得删视频?那就转移到电脑硬盘上来吧,在Windows中使用本软件进行查看.搜索,手机上的空间就可以腾出来了!本文详细介绍了软件的使用说明,以及介绍了微信聊天记录数据存储格式,并给出了本软件与源代码的下载地址,最后是iPhone聊天记录中图片与视频数据的清理方法. 1. 前

android录像增加时间记录(源码里修改)

需要做一个功能,录像和播放时都显示录时的时间,参考文章链接找不到了,不好意思,这里记录一下,防止下次找不到了.另一篇关于源码录像的流程请参考 http://www.verydemo.com/demo_c131_i79000.html 在源码CameraSource.cpp中的dataCallbackTimestamp这个函数里增加如下代码 #ifdef HAVE_AEE_FEATURE if(data == NULL || data->size() <= 0) aee_system_excep

linux下用shell脚本删除mysql记录ssc源码搭建

mysql下删除记录较多的ssc源码搭建会出现如下错误:企 娥:217 1793 408 Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: No operations allowed after connection closed. 因此需要分批删除表中数据,脚本如下: #!/bin/bashDB_USER="root"DB_PASS="pw"DB_HOS

LNMP环境搭建记录(源码方式)

LNMP指的是在Linux下用PHP+MYSQL+NGIX搭建网站的环境. Nginx是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器.Nginx不仅可以作为web服务器,也可以作为负载均衡器. MySQL是一款开源免费的数据软件,MySQL是一个小型关系型数据库管理系统,其体积小.速度快.总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库. PHP,是英文超级文本预处理语言Hypert

微信小程序支付代码asp源码下载

昨天晚上给朋友写了一个asp的微信小程序支付接口,我这朋友的小程序服务器端用的asp做的,以前没有支付,非让我给写一个支付,因为必须是asp来写,他不会,所以我就帮他写了,顺便还写了一个asp获取用户资料头像和微信名入库的代码,也是asp源码,数据库用的是mdb的格式,还可以比较好用,微信小程序用asp做服务器端估计很少,应该有朋友需要,下载这个代码:ly.ftphn.com/wxpay.rar ============================================= 互相学习