Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >微信公众平台开发[6] —— 微信开发集成类的使用

微信公众平台开发[6] —— 微信开发集成类的使用

作者头像
泥豆芽儿 MT
发布于 2018-09-11 03:22:25
发布于 2018-09-11 03:22:25
2.2K00
代码可运行
举报
运行总次数:0
代码可运行

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://cloud.tencent.com/developer/article/1333726

背景

  这几天又在接触微信PHP方面的开发,认为之前写的文章确实有些乱,刚好发现了一个不错的集成类(看原始代码,出自“云知梦军哥”,不算打广告,只是尊重别人的开发成果,谢谢)里面涉及了非常全面的函数,在此针对我自己的实际使用过程简单的描述一下希望能给同道小白们一个诚恳的引导 ...

  框架:ThinkPHP 3.2.3

前期准备:

①.微信公众平台的配置

这里不赘述,具体的可以参考我前面所写的1、2章,个人认为还是比较全面的

②. 将文件 Weixin.class.php 放在对应的 library 目录中

不过本人人开发是基于 ThinkPHP 框架,如果使用了其它的方式,注意更改引用路径,相信还是较为容易的,参考截图如下:

③. 对应的数据库中需要新建一个表

当然,后期优化可以考虑去掉或自行设计,在这里个人觉得比较合理,也方便自己测试(公众号在线接口调试工具)

④. 此表是用来微信授权时自动存储公众号信息及其token 获取时间

而对应操作此表的代码位于 Weixin.class 中的 getaccesstoken()方法, 如果不是采用的 ThinkPHP 框架,可针对此方法中的 sql 语句进行替换截取部分代码可供参考

一.开发者模式配置

①. 参考配置截图

②. 注意匹配对应目录以及令牌

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/**
 * 微信开发配置控制器
 * Class WeixinController
 * @package M\Controller
 */
class WeixinController extends Controller
{
    public function index()
    {
        import('Org.Wechat.Weixin');
        //参数传值 token、AppID、AppSecert
        $wechat = new \Weixin('zxxxi', 'wxxxxxxxxx89', 'efxxxxxxxxxxxxxxxxxxxxxxxb7');
        if (!isset($_GET['echostr'])) {
            //TODO 调用响应消息函数 自动回复
            $wechat->responseMsg();
        } else {
            //实现网址接入,调用验证消息函数
            $wechat->valid();
        }
    }
}

③. 必要文件上传

微信公众平台近期发现规定需要在相应域名的根目录下上传文件,具体可从公众号下载。

二. 请求授权登录,获取微信用户信息

①. 代码参考

下面是本人摘抄并精简的部分代码,具体的业务逻辑需要自己相应进行补充或删减

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import('Org.Wechat.Weixin');
//参数传值 token、AppID、AppSecert
$wechat=new \Weixin('zxxxxi','wxxxxxxxxxxxxx9','efxxxxxxxxxxxxxxxxxxxxxxxxxxxx7');
//可理解为这是当下的链接地址
$url = "http://www.xxxxx.com".$_SERVER['REQUEST_URI'];
//TODO 判断 memcache是否有值,是否过期 (此处只是一个判断举例)
if(!S(session('XXXNAME').'_NAMEID')){
   if(!$_GET['code']){
      $redirect_uri = $url;
      $urls=$wechat->getOauthRedirect($redirect_uri);
      header("Location:".$urls);
      die;
   }
}
$reT=$wechat->getOauthAccessToken();
//TODO 如果获得 token值
if($reT){
   $openid = $reT['openid'];
   $user_info = $wechat->getOauthUserinfo($reT['access_token'],$openid);
   //查询数据库是否存在
   $userData = M('users')
      ->where("openid = '$openid'")
      ->Field('user_id,user_name,abnormal')
      ->find();
   if ($userData['user_id']) {
      //执行操作 或者跳转页面
      header("Location:???????");
   }else{
      //没有帐号需要转到用户名填写页面来完成授权
      $maxuid = M('users')->max('user_id');
      $user['openid'] = $openid;
      $user['nickname'] = $user_info['nickname'];
      $user['sex'] = $user_info['sex'];
      $user['reg_time'] = time();
      $user['user_img'] = $user_info['headimgurl'];
      //TODO 进行新用户的添加
      $addTag = add('users',$user);
   }
}else{
//重新跳转,或其他操作...
}

②. 手机微信端登录对应链接的结果

③. 补充说明

$user_info = $wechat->getOauthUserinfo($reT'access_token',$openid);

此处返回的$user_info 为授权用户的详细信息,可追踪方法查看源代码中 OAUTH_USERINFO_URL 的定义开发者文档有介绍其意义,之前的两篇文章里也做了简单介绍

三、微信端分享功能

①. 配置微信分享相应数据

下面的方法个人设计面向对象时是在继承的 Controller 构造函数中初始化调用的,大家可以按自己需求放置

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/**
 * 配置微信分享功能
 */
public function getWxShare(){
    import('Org.Wechat.Weixin');
    $wechat=new \Weixin('zxxxxi','wxxxxxxxxxxxx9','efxxxxxxxxxxxxxxxxxxb7');
    $url = "http://www.xxxxxmi.com".$_SERVER['REQUEST_URI'];
    $res = $wechat->getJsSign($url);
    $res['wxurl'] = $url;
    $this->assign('wx',$res);
}

②. 前台页面的配置信息

多数就是 html 前台文件,补充如下的 js 代码,具体的数据可自己修改

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<script src="http://res.wx.qq.com/open/js/jweixin-1.1.0.js" type="text/javascript"></script>
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<script>
    /**
     * Created by 百鬼夜行 on 2017/4/27.
     */
    //通过config接口注入权限验证配置
    wx.config({
        debug : false,
        appId : "{$wx.appid}",
        timestamp : "{$wx.timestamp}",
        nonceStr : "{$wx.noncestr}",
        url : "{$wx.url}",
        signature : "{$wx.signature}",
        jsApiList : ['onMenuShareTimeline', 'onMenuShareAppMessage', 'onMenuShareQQ', 'onMenuShareWeibo']
    });
    wx.ready(function(){
        //朋友圈
        wx.onMenuShareTimeline({
            title : "真米如初:美好的东西 如期相遇 值得期待",  // 分享标题
            link : "{$wx.wxurl}",  // 分享链接
            desc : "关注饮食,品质生活。您的健康,是我们最好的坚持,有真米,生活才够美!",  //分享描述
            imgUrl : "http://img.52zhenmi.com/Public/upload/20170426/149321008494428.jpg", // 分享图标
        });
        //发送给好友
        wx.onMenuShareAppMessage({
            title : "真米如初:美好的东西 如期相遇 值得期待",  // 分享标题
            link : "{$wx.wxurl}",  // 分享链接
            desc : "关注饮食,品质生活。您的健康,是我们最好的坚持,有真米,生活才够美!",  //分享描述
            imgUrl : "http://img.52zhenmi.com/Public/upload/20170426/149321008494428.jpg", // 分享图标
        });
        //QQ好友
        wx.onMenuShareQQ({
            title : "真米如初:美好的东西 如期相遇 值得期待",  // 分享标题
            link : "{$wx.wxurl}",  // 分享链接
            desc : "关注饮食,品质生活。您的健康,是我们最好的坚持,有真米,生活才够美!",  //分享描述
            imgUrl : "http://img.52zhenmi.com/Public/upload/20170426/149321008494428.jpg", // 分享图标
        });
        //腾讯微博
        wx.onMenuShareWeibo({
            title : "真米如初:美好的东西 如期相遇 值得期待",  // 分享标题
            link : "{$wx.wxurl}",  // 分享链接
            desc : "关注饮食,品质生活。您的健康,是我们最好的坚持,有真米,生活才够美!",  //分享描述
            imgUrl : "http://img.52zhenmi.com/Public/upload/20170426/149321008494428.jpg", // 分享图标
        });
    });
</script>

③. 最终实现的效果如下

补充提醒:

(1).首先要保证开发配置信息的准确性 (2).有时会出现token令牌失效的情况,注意本地测试时很可能会影响线上,应该就是获取新的令牌使得线上的数据库中不对应,注意一下。 (3).分享页面的操作,为了方便处理可能出现的失败情况,可以先用调试模式将wx.config中的 debug值更改为true,待正确无误后再改回来。针对具体的报错信息需要查询微信开发者文档,相信每一个想走程序猿道路的人,都会强制习惯补坑填坑 ...

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
debug : true,

四、公众号发送消息

可用于简单消息的发送,比如用户购物完成后对公众号管理员的消息提醒等.

①. 前提

所要发送信息的用户关注了当前的公众号

②. 代码举例

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/**
 * 此方法不支持 图片发送 注意文字的换行显示
 */
public function postMsg(){
    import('Org.Wechat.Weixin');
    $wechat=new \Weixin('zxxxxi','wxxxxxxxxxx9','efxxxxxxxxxxxxxxxxxxxxxxxxxb7');
    $content = "微信公众号发送:\n";
    $content .= "人生如戏,我们以为可以改变自己的命运,却没想到我们的结局早已注定。\n无论怎么做都摆脱不了戏里既定的安排,可谓殊途同归。";
    $content .= "如此看来,我们的拼搏和挣扎就像小丑在跳舞,徒惹人发笑罢了。";
    //TODO 微信用户唯一标记-openID 前提是对方已经关注公众号
    $wxOpenID = "oIaCOxxxxxxxxxxxxxxxxxxxxFe0";
    $wechat->postMaggerToUser($wxOpenID,$content);
}

③. 实现效果

五、公众号自动回复

功能主要用于用户操作公众号时的触发事件处理,比如关注时的消息发送、按钮点击的监听等

①. 主要的配置

其实来源于上面第一节对开发者模式的配置,而举例代码中 WeixinController 的 index()重要的就是那不到十行的代码

②. 监听响应消息的函数

监听响应消息的函数为 Weixin.class 中的 responseMsg(),对于其中详细的数据处理可根据不同的触发事件路径进行代码的修改

③. 举例:关注公众号后的消息发送

④. 举例:

根据用户的输入进行消息的自动回复,代码实际开发中可根据获得的文字进行项目数据库中的文字匹配,此处简单演示即可。

⑤. 效果实现截图

附录

因为集成的微信类代码偏多,不在此粘贴,可从下面的链接进行下载参考

①. 前期文章参考

获取用户Openid及个人信息 参考文章二:微信端分享功能

②. 源代码

源代码下载 >>>

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017年05月04日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Django+wechatpy接入微信公众平台以及授权登录
确定Django环境可以正常运行,环境搭建见:Linux 搭建Nginx+uwsgi+Django环境 安装 wechatpy[cryptography] sudo pip3 install wechatpy[cryptography] 修改settings.py 接入微信公众号的连接去掉csrf验证,详情参考:解决Django+Vue前后端分离的跨域问题及关闭csrf验证的后半部分 在settings.py 加入微信公众号配置 AppID = '' AppSecret = '' Token = ''
lin_zone
2019/05/08
2.7K0
微信公众平台开发获取用户基本信息--转
本文介绍如何获得微信公众平台关注用户的基本信息,包括昵称、头像、性别、国家、省份、城市、语言。 本文的方法将囊括订阅号和服务号以及自定义菜单各种场景,无论是否有高级接口权限,都有办法来获得用户基本信息,而无需模拟登录。 在本文中,特别要注意的是有两个不同的Access Token,他们产生的方式不一样,一种是使用AppID和AppSecret获取的access_token,一种是OAuth2.0授权中产生的access_token,方倍工作室分别称为全局Access Token和授权Access Token
李海彬
2018/03/20
1.7K0
ASP.NET MVC5+EF6+EasyUI 后台管理系统(70)-微信公众平台开发-成为开发者
前言: 一、阅读这段系列之前,你必须花半天时间大致阅读微信公众平台的API文档,我尽量以简短快速的语言与大家分享一个过程 二、借助微信公众平台SDK Senparc.Weixin for C#,所以你必须对Senparc进行独立的了解 http://weixin.senparc.com/ 三、如果配置遇到困难,下载文章尾部源码进行参考 ---------------------------------------------------资源-------------------------------
用户1149182
2018/01/16
9220
ASP.NET MVC5+EF6+EasyUI 后台管理系统(70)-微信公众平台开发-成为开发者
微信公众号推送如何写代码
写微信公众号推送的代码需要用到微信公众平台提供的开发者文档和API接口。以下是一个示例代码,包含了获取用户信息和回复文本消息:
hide
2023/12/12
3390
微信公众号推送如何写代码
微信公众平台开发(四)——微信网页授权:获取用户openid&用户基本信息
在开发中,如果web产品需要使用到微信的功能,比如微信授权登录、微信支付、微信投票等,我是开发的东东是一个web项目,然而如果需要接入微信的话,就需要使用道微信的微信网页开发相关的功能。 其中我们需要的东西就是拿到微信服务器的回调,比如用户扫码登录我们的web项目时,用户正确授权之后,微信服务器能回调到我们期望的url并且返回相应的参数信息。
不愿意做鱼的小鲸鱼
2023/03/25
15.9K0
微信公众平台开发(四)——微信网页授权:获取用户openid&用户基本信息
微信公众平台开放JS-SDK(微信内网页开发工具包)
微信公众平台开放JS-SDK(微信内网页开发工具包),这次开放接口是质的飞跃,是对开发者和广大用户一个利好的消息。未来的公众号图文消息会更丰富多彩,准备脑洞大开吧!(第三方平台正式支持接入微信公众平台JS-SDK) 微信公众平台今日面向开发者开放微信内网页开发工具包(微信JS-SDK)。 通过微信JS-SDK提供的11类接口集,开发者不仅能够在网页上使用微信本身的拍照、选图、语音、位置等基本能力,还可以直接使用微信分享、扫一扫、卡券、支付等微信特有的能力,为微信用户提供更优质的网页体验。 微信JS-SDK主
ytkah
2018/03/05
13K0
微信公众平台 获取用户openid
知道逻辑之后,我们需要具体操作,在实际操作中,我们还需要注意几点,首先,是理解我们第一个访问的网址url1,它有6个参数。
全栈程序员站长
2022/09/14
3.6K0
Spring Security 6.x 微信公众平台OAuth2授权实战
上一篇介绍了OAuth2协议的基本原理,以及Spring Security框架中自带的OAuth2客户端GitHub的实现细节,本篇以微信公众号网页授权登录为目的,介绍如何在原框架基础上定制开发OAuth2客户端。
fullstackyang
2024/06/23
5610
Spring Security 6.x 微信公众平台OAuth2授权实战
使用微信测试账号对网页进行授权
如果用户在微信客户端中访问第三方网页,公众号可以通过微信网页授权机制,来获取用户基本信息,进而实现业务逻辑。我们在进行公众号网页开发的时候,想要获取用户的基本信息,首先得获取到access_token,从access_token里我们要拿出用户的openid来作为用户在我们系统中的唯一标识,以及通过openid可以保证该用户的只能访问到与其openid相对应的数据,防止越权漏洞。因此,我们需要对网页进行授权,否则是无法在获取到用户的openid的。
端碗吹水
2020/09/23
4.5K0
使用微信测试账号对网页进行授权
微信公众号网页开发-Vue项目坑点分析
该系统为商品推广系统,微信交互涉及网页授权和网页分享,年前使用django框架做了基础版,节后项目升级,功能更加丰富,使用vue框架做前后端分离开发,前后端分离开发提升了开发效率,也埋藏了很多坑点。。。
全栈程序员站长
2022/09/06
1.1K0
微信公众号网页开发-Vue项目坑点分析
Java微信公众平台开发(十)--微信用户信息的获取 (一)关注被动回复图文消息的实现。(二)pc界面显示用户
前面的文章有讲到微信的一系列开发文章,包括token获取、菜单创建等,在这一篇将讲述在微信公众平台开发中如何获取微信用户的信息,在上一篇我们有说道微信用户和微信公众账号之间的联系可以通过Openid关联,所以在这里我们就采用openid去获取用户微信信息。并实现两个个简单场景应用:(一)当微信新用户关注我们的微信公众平台的时候我们自动回复一篇图文消息,然后在图文消息中标题为:【尊敬的:XXX,你好!】,而且在图文消息中的图片就是用户的微信头像,如下图:(二)pc界面显示用户的昵称,性别,头像
用户2417870
2019/09/18
1.2K0
Java微信公众平台开发(十)--微信用户信息的获取

        (一)关注被动回复图文消息的实现。(二)pc界面显示用户
PHP 网站应用微信登录
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u011415782/article/details/76221707
泥豆芽儿 MT
2018/09/11
5K0
PHP 网站应用微信登录
微信网页开发
套用《围城》里老学究的的一句开场白:"兄弟我刚入行的时候…“兄弟我是很不喜欢微信这样一款应用的——尽管我在2011年就已经是微信的注册用户。在我看来,第一个,能用qq达到的目的为什么还要微信?其次,凭什么一个开发要绑在一款微信里?但是,周边的人似乎在我毕业的前后通通用上了微信。
一粒小麦
2019/08/13
4.2K0
记录一次开发微信网页分享
最近在做一个项目需求,分享领好书活动,获取用户的个人信息以及unionID,并诱导用户分享给好友或朋友圈,达到裂变拉新的目的。在做的过程中遇到了一些坑的地方,所以回过来总结一下
super.x
2019/07/02
1.5K0
微信公众号开发——2、微信网页开发
在公众号平台下,自定义菜单,添加菜单,并选择菜单内容跳转到指定页面地址即可(需认证后方可添加页面地址,个人账号暂不支持认证)。
全栈程序员站长
2022/09/01
7.8K0
微信公众平台开发 自定义菜单
自定义菜单能够帮助公众号丰富界面,让用户更好更快地理解公众号的功能。开启自定义菜单后,公众号界面如图所示:
庞小明
2018/09/19
2.1K0
微信公众平台开发 自定义菜单
Yii2.0实现微信公众号后台开发
1.用户授权接口:获取access_token、openid等;获取并保存用户资料到数据库
botkenni
2019/09/02
9880
手机端公众号内的微信第三方登录
OAuth(开放授权)是一个开放标准,允许用户让第三方应用访问该用户在某一网站上存储的私密的资源(如照片,视频,联系人列表),而无需将用户名和密码提供给第三方应用。
山河木马
2019/03/05
3.3K0
手机端公众号内的微信第三方登录
Java微信公众平台开发_05_微信网页授权
登录微信公众平台后台, 开发 - 接口权限 - 网页服务 - 网页帐号 - 网页授权获取用户基本信息 - 修改,
shirayner
2018/08/10
6.5K1
Java微信公众平台开发_05_微信网页授权
微信开发-微信分享和支付模块代码记录
1、微信是不支持直接链接分享的,也就是如果你是别人给你的链接直接点开分享是不可以的 2、微信支持点击收藏以后分享出去 3、微信支持从公众号直接分享出去
何处锦绣不灰堆
2022/05/09
1.4K0
微信开发-微信分享和支付模块代码记录
推荐阅读
相关推荐
Django+wechatpy接入微信公众平台以及授权登录
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验