微信公众号开发基础框架—入门级

7 篇文章 0 订阅
1 篇文章 0 订阅

公众号和小程序作为微信的两大生态,对于开发者而言。基本上是绕不过去的两座大山。前面我已经出了几期博客关于小程序授权登录的。那么今天就来分享一下关于公众号授权回调这块吧。业务场景:假如需要做一个公众号表单收集,那么第一步绕不开的是不是还是授权呢?

1.准备工作 

        相信很多程序员一般接手的都是他人项目进行二次开发,所以基本也很少去考虑项目底层的架构,请求的封装,权限的控制,路由的拦截等等这些。这些都是别人做好的,我们拿来即用就行,只管关注写页面和对接口就行。但是,如果不试试从零开始做一个完整的项目,你又怎么知道自己的不足呢。

        假如,现在一个问题摆在你面前,leader要你做一个公众号进行用户信息及表单收集。整个前端就只有你自己。试问此刻阁下又该如何自处?

        底层框架的搭建,直接去git或开源社区上找。我并不反对在他人开源的项目基础上做二次开发,毕竟站在巨人的肩膀上会让我们更加事半功倍。前提你拥有理解并改动他人底层代码的能力。使其更加契合你系统本身的业务。

下面以该基础框架项目做演示,也是在git上找的。并经过了本地测试(利用测试公众号脱离后端的情况下)。实现了授权回调。

1.公众号H5基础框架https://download.csdn.net/download/qq_34761385/89045823

2.先理解下公众号官方文档关于授权这块的说法:

网页授权 | 微信开放文档

 3.申请测试公众号

 微信公众平台  去该平台申请一个测试公众号,获取公众号的appid和secret。

2.本地调试过程

        将代码下载到本地运行后,即可在微信开发者工具中打开地址。访问后就会不出意外的报错。不要害怕,我们针对问题一步步解决,这个解决问题的过程也是我们了解微信公众号生态的过程。

tips:这里有人会有疑问,为什么能授权回调获取到信息,一般不是通过后端才能解密获取吗,这里是因为用了代理。直接和微信服务器做了对接。

这里授权回调核心代码就是app.vue

<template>
  <div id="app">
    <div v-if="isLoading" class="loading">
      <img
        src="./assets/public/loading.gif"
        alt="图片加载失败"
        srcset=""
      >
      <p>加载中...</p>
    </div>
    <div v-else-if="!isLoading && runEnv === 1" class="warning">
      <img
        src="./assets/public/warning.png"
        alt="图片加载失败"
        srcset=""
      >
      <p class="errorColor">本地调试请在微信开发者工具中打开</p>
      <ul>
        <li>1.微信开发者工具左上角-->微信开发者工具</li>
        <li>2.更换开发模式-->公众号网页调试</li>
        <li>
          <span>3.输入</span>
          <van-button v-copy="open_url" type="primary" size="mini">复制</van-button><br>
          <span>{{ open_url }}</span><br>
          <span class="errorColor">务必是该公众号的开发人员并且关注了公众号</span>
        </li>
      </ul>
    </div>
    <div v-else-if="!isLoading && runEnv === 2" class="warning">
      <img
        src="./assets/public/warning.png"
        alt="图片加载失败"
        srcset=""
      >
      <p class="errorColor">请在微信中打开</p>
    </div>
    <div v-else-if="!isLoading && runEnv === 4" class="warning">
      <img
        src="./assets/public/warning.png"
        alt="图片加载失败"
        srcset=""
      >
      <p class="errorColor">加载失败,请刷新或退出重试</p>
    </div>
    <router-view v-else-if="(!isLoading && runEnv === 0) || (!isLoading && runEnv === 3)" />
  </div>
</template>

<script>
import wx from '@/utils/wx'
import { getWxToekn, getWxUserInfo } from '@/api/public'
export default {
  name: 'App',
  data() {
    return {
      // 微信配置
      wxConfig: {
        appid: 'wxc3c853868437900d',
        AppSecret: '3ba0e66a7a12fd1434f2fbbd759143ef',
        // 本地的时候需要netapp映射一下,具体可百度
        redirect_url: process.env.NODE_ENV === 'development' ? 'http://liuqing.top:8080' : location.protocol + '//' + location.host,
        // 应用授权作用域,snsapi_base (不弹出授权页面,直接跳转,只能获取用户openid),snsapi_userinfo (弹出授权页面,可通过openid拿到昵称、性别、所在地。并且,即使在未关注的情况下,只要用户授权,也能获取其信息)
        scope: 'snsapi_userinfo',
        // 重定向后会带上state参数,开发者可以填写a-zA-Z0-9的参数值,最多128字节
        state: '0',
        // 获取code
        code: this.$func.getUrlParam('code')
      },
      // 微信的url
      open_url: '',
      // 是否加载完毕
      isLoading: true,
      // 0:本地,开发者工具环境  1:本地,浏览器环境  2:线上,浏览器环境 3:线上,微信环境 4:线上或本地(开发者工具环境)->但是加载wx-sdk失败了
      runEnv: -1
    }
  },
  mounted() {
    // 需要微信回调code的url
    this.open_url =
    'https://open.weixin.qq.com/connect/oauth2/authorize?appid=' + this.wxConfig.appid +
    '&redirect_uri=' + this.wxConfig.redirect_url +
    '&response_type=code' +
    '&scope=' + this.wxConfig.scope +
    '&state=' + this.wxConfig.state +
    '#wechat_redirect'
    // 微信环境准备
    wx(this.wxConfig, this.open_url).then((obj) => {
      this.runEnv = obj.env
      // 获取token
      getWxToekn({
        appid: this.wxConfig.appid,
        secret: this.wxConfig.AppSecret,
        code: this.wxConfig.code,
        grant_type: 'authorization_code'
      }).then(res => {
        this.$store.commit('user/wxUserAc', res)
        // 获取用户信息
        getWxUserInfo({ openid: res.openid, access_token: res.access_token }).then(res2 => {
          this.isLoading = false
          this.$store.commit('user/wxUser', res2)
        })
      })
    }).catch((obj) => {
      this.isLoading = false
      this.runEnv = obj.env
      this.$notify({ type: 'danger', message: obj.msg })
    })
  },
  methods: {
  }
}
</script>

<style lang="css" scoped>
#app {
  width: 92%;
  padding: 0 4%;
  margin-top: 40px;
  word-wrap:break-word;
  word-break:break-all;
}
#app .warning > img {
  display: block;
  margin: 0 auto;
}
.errorColor {
  color: #ff4a4a;
}
#app .warning > p {
  text-align: center;
  font-size: 16px;
  margin-top: 30px;
}
#app .warning > ul > li {
  margin: 5% 0;
}
#app .warning > ul > li > span.errorColor {
  font-size: 14px;
}
#app .loading {
  width: 100%;
}
#app .loading > img {
  width: 100%;
  height: 100%;
}
#app .loading > p {
  font-size: 16px;
  text-align: center;
  font-weight: 600;
  padding: 0;
  margin: 0;
}
</style>

下面我要说的就是涉及后端做的工作,但是因为这里我们用到了测试公众号,又是走的代理直接对接微信服务请求,所以就绕过了后端。 

从这里的回调地址构建代码就能看出来,appid和AppSecret填写你申请的测试公众号的,微信开发是需要有开发权限的,所以别忘了去扫码关注测试号,绑定上你的微信号。然后,回调一般来说必须走域名,而且域名还要做公众号网页授权回调域名绑定。这里我们在测试公众号进行绑定就行,域名+端口的形式。

因为本地一般都是走的ip+端口。那么怎么实现域名加端口能访问到本地启动的服务呢,这里我们就涉及到了hosts文件的修改了,一般在C:\Windows\System32\drivers\etc目录下。

这样就实现了本地的授权回调了,通过这一系列操作,是不是对微信公众号的开发有了更深刻的理解了呢。

  • 22
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
phpWechat 是由一个具有多年行业开发经验的前端 UI 设计师、PHP开发工程师组成的团队设计、研发的一套的微信公众平台管理系统,您可以瞬间完成一个公共号或者PC站或者两者皆有的平台搭建。 phpWeChat 微信+网站开发框架功能亮点: 1、100%开源,没有任何加密文件 phpWeChat核心文件100%开源,没有任何加密文件,开发者可以放心使用而无需担心留有后门程序等。 2、程序轻量级,一天读完所有代码 核心框架压缩包只有2.66M,十分利于开发者迅速阅读全部代码。 3、代码严谨,结构清晰 phpWeChat使用MVC开发模式,各个功能模块之间独立并目录结构统一。开发者可迅速掌握phpWeChat的框架结构。 4、二次开发文档十分完善 我们提供了完善的phpWeChat二次开发文档,便于开发者学习与查阅。 5、高度集成微信接口 phpWeChat高度集成了微信公共号的自动回复、菜单管理、素材管理、模板消息、粉丝管理、微信支付等常用接口,您只需一个函数或2/3行代码即可实现原本需要很费时费力才能开发的功能。 6、phpWeChat也是一个PC(网站)开发框架和CMS 慢慢您会发现,phpWeChat是一个更接近CMS功能的框架。 7、高度封装常用开发功能 只需一两行固定的代码,您便可以写出列表分页、微信支付、文件上传、邮件发送、短信发送等功能。 8、数据结构合理,负载强劲 phpWeChat集成了常见的内存级缓存(MemCache)、文件缓存处理方案,使得系统更符合大数据、大并发的公共号或网站使用。 9、集成应用市场,功能拓展一瞬间 phpWeChat集成了应用市场并在线安装应用的功能,您可以在一瞬间安装完成其他开发开发的功能模块。 phpWeChat安装方法: 将下载的程序压缩包(zip格式)解压后,将全部文件和文件夹上传至网站根目录。然后输入域名/install.php 即可进入安装程序。 注意:安装phpWeChat前请先创建好phpWeChat所需的数据库。 phpWeChat 目录结构: addons 功能模块目录 admin 公用后台目录 api 插件目录 data 数据缓存目录 install 安装程序目录,安装后请改名或删除 include 公用操作类目录 statics 静态文件目录 template 视图(模板)目录 upload 上传文件存放目录 phpWeChat 更新日志: 新版v1.0.3发布: phpWeChat PC+微信公众号开发核心框架v1.0.3针对v1.0.2版本出现的问题,主要修复了和增加了以下功能: 1、优化自定义模块操作; 2、优化安装过程; 3、修复一处在线支付的PHP版本兼容问题; 4、修复一处自定义模块的问题; 5、修复后台模块管理显示未知版本的bug; 6、修复粉丝行为IP报错的Bug; 7、删除一些冗余代码; 8、修复消息模板不存在时,一直提示[同步中]的bug。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

流情

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值