首页 > 编程语言 >【小程序】微信小程序开发流程

【小程序】微信小程序开发流程

时间:2023-04-09 18:01:36浏览次数:42  
标签:code 登录 微信 流程 程序开发 程序 用户 开发

目录

一、概述

微信小程序是一种基于微信平台的应用程序,用户可以在微信中直接使用这些小程序,无需下载和安装,具有轻便、快速、实用等特点。

  • 微信小程序通常可以提供各种服务和功能,例如购物、预定、社交、游戏等等。开发者可以使用微信小程序开发工具进行开发,并上传至微信平台发布。用户可以通过微信内置的小程序搜索或扫描二维码进入小程序,也可以通过分享链接进入。

  • 微信小程序可以在微信中使用,无需打开其他应用程序,也无需下载和安装,因此具有便捷、快速、节省手机存储空间等优势。另外,微信小程序也支持各种应用场景,如公共交通、旅游景区、餐饮服务等等。

总之,微信小程序是一个非常有用的工具,它提供了各种方便的服务和功能,同时也为开发者提供了一个便捷的开发平台。
在这里插入图片描述

要做微信小程序开发需要几个前提条件:

  1. 注册一个微信小程序账号,如果觉得太麻烦,可以去某宝找人帮你注册一个。
  2. 安装开发工具

官方地址:https://mp.weixin.qq.com/
官方文档地址:https://developers.weixin.qq.com/miniprogram/dev/framework/

二、整体开发架构

主要分为两块:一部分就是微信小程序端也就是前端,但是也提供了云端开发;一部分就是后端,后端会连着各种外部资源。其实跟其它非小程序开发流程是一样的。
在这里插入图片描述

三、注册账号和安装开发工具

1)注册账号

开发小程序的第一步,你需要拥有一个小程序帐号,通过这个帐号你就可以管理你的小程序。

1、注册方法

在微信公众平台官网首页(https://mp.weixin.qq.com/)点击右上角的“立即注册”按钮。
在这里插入图片描述

2、选择注册的帐号类型

选择“小程序”,点击“查看类型区别”可查看不同类型帐号的区别和优势。
在这里插入图片描述

3、填写邮箱和密码

请填写未注册过公众平台、开放平台、企业号、未绑定个人号的邮箱。
在这里插入图片描述

【温馨提示】在填写小程序注册信息之前,需要先注册一个邮箱,其中每个邮箱只能申请一个小程序。并且,已经绑定了其他的公众号、小程序、个人号的邮箱,不能重新注册新的小程序。

4、激活邮箱

点击“注册”之后,跳转到邮箱激活页,激活账号,继续注册流程。
在这里插入图片描述

5、填写主体信息

点击激活链接后,继续下一步的注册流程。请选择主体类型选择,完善主体信息和管理员信息。

选择主体类型,这里选择个人,当然也可以选择企业:
在这里插入图片描述

主体类型说明如下:
在这里插入图片描述

1个身份证号码和一个手机号码只能注册5个小程序。注意主体信息提交后不可更改。
在这里插入图片描述

如果选择的是企业类型帐号,这种账号可选择两种主体验证方式(如果是选择个人账号类型。以下内容就可以忽略了)。

  • 方式一:支付验证

需要用公司的对公账户向腾讯公司打款来验证主体身份,打款信息在提交主体信息后可以查看到。
请根据页面提示,向指定的收款帐号汇入指定金额。

温馨提示:请在10天内完成汇款,否则将注册失败。

  • 方式二:微信认证

通过微信认证验证主体身份,需支付300元认证费。认证通过前,小程序部分功能暂无法使用。

在这里插入图片描述
填写管理员信息
在这里插入图片描述
确认主体信息不可变更
在这里插入图片描述

6、登录后台补充信息

在小程序管理后台中,补充小程序的基本信息,如名称、图标、描述等。

在这里插入图片描述

【温馨提示】如果你的公众号是服务号且已经认证,可以使用“快速注册认证小程序流程”,无需重新提交主体材料、无需对公打款、无需支付300元认证费用。

2)安装开发工具

下载地址:https://developers.weixin.qq.com/miniprogram/dev/devtools/devtools.html
在这里插入图片描述

3)快速开始

在开始之前说一下几个知识点。

1、云开发和传统开发的区别

  • 云开发就是一套解决小程序前后端开发的一种云端能力
  • 它提供了一整套云服务及简单、易用的 API 和管理界面,以尽可能降低后端开发成本,让开发者能够专注于核心业务逻辑的开发、尽可能轻松的完成后端的操作和管理
  • 云开发包含了小程序前端和小程序后端。

传统开发:
在这里插入图片描述
云开发:
在这里插入图片描述

  • 可能刚入门的小程序制作开发人员对这样的官方介绍有点摸不着头脑。直白点说,所谓的云端能力实际上就是服务器端(后端),开发者自己不需要本地配置服务器和数据库、存储、云函数等基础能力,直接在微信官方提供的服务器端操作就行了。

  • 而普通的开发,是需要自己准备服务器而且以上提到的基础能力。所以小程序云开发相对普通的开发,最大的优势就是更方便、更高效,节省开发成本。

使用传统开发的优缺点:

  • 优点 : 我们不用管后台逻辑, 直接发送请求即可获取想要的数据
  • 缺点 : 开发成本太大, 不能个人开发,需要域名、服务器和学习新编程语言

使用云开发的优缺点:

  • 优点 : 完全可以个人开发前后端, 直接上线, 不需要依赖后端, 更重要的是简单易学
  • 缺点 : 前后端都是我们自己写 , 得学习云开发之类的API

云开发和传统开发的其它区别:

对比项 云开发 传统服务器
难易程度 简单 复杂
部署难易 基本上不用部署 部署费时费力
是否需要域名 不需要 需要
是否需要备案 不需要 需要
是否支持https 不需要 需要
适合公司 中小型公司、个人 大公司
学习难易 容易上手 学习起来比较难
费用 免费版基本够用 200-2000/年

2、云开发 API 分类

1)云函数

  • 云函数是一段运行在云端的代码,无需管理服务器,在开发工具内编写、一键上传部署即可运行后端代码。
  • 小程序内提供了专门用于云函数调用的 API。开发者可以在云函数内使用 wx-server- sdk 提供的 getWXContext 方法获取到每次调用的上下文(appidopenid 等),无需维护复杂的鉴权机制,即可获取天然可信任的用户登录态(openid

2)云数据库

  • 一个既可在小程序前端操作, 也能在云函数中读写的 MongoDB 数据库
  • 一个数据库可以有多个集合(相当于关系型数据中的表),集合可看做一个 JSON 数组,数组中的每个对象就是一条记录,记录的格式是 JSON 对象

3)云存储

  • 云开发提供了一块存储空间,在小程序前端直接上传/下载云端文件能力,在云开发控制台可视化管理
  • 在小程序端可以分别调用 wx.cloud.uploadFilewx.cloud.downloadFile 完成上传和下载云文件操作

3、AppID 获取

注册了账号就可以直接登录后台获取AppID了。
在这里插入图片描述

4、快速开始

创建小程序,AppID就是上面获取的。

传统开发:
在这里插入图片描述

四、小程序登录流程

1)登录流程时序流程图

先来看一下微信小程序登录流程图吧,官方地址:https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/login.html
在这里插入图片描述
说明

  • 调用 wx.login() 获取 临时登录凭证code ,并回传到开发者服务器。
  • 调用 auth.code2Session 接口,换取 用户唯一标识 OpenID 、 用户在微信开放平台帐号下的唯一标识UnionID(若当前小程序已绑定到微信开放平台帐号) 和 会话密钥 session_key

之后开发者服务器可以根据用户标识来生成自定义登录态,用于后续业务逻辑中前后端交互时识别用户身份。

【注意事项】

  • 会话密钥 session_key 是对用户数据进行 加密签名 的密钥。为了应用自身的数据安全,开发者服务器不应该把会话密钥下发到小程序,也不应该对外提供这个密钥。
  • 临时登录凭证 code 只能使用一次

2)认识openid,unionid 和code

  • openid:openid是用来唯一标识用户的一个字符串。在微信小程序中,每个用户的openid都是唯一的。通过openid,小程序可以获取用户的基本信息,如头像、昵称等。

【注意】同一个用户在不同的小程序中拥有不同的openid。因此,在开发小程序时,不能使用openid来进行用户的唯一性判断。

  • unionidunionid 是在用户绑定同一微信开放平台账号下的多个应用时,用来唯一标识用户的一个字符串。如果用户在多个小程序中使用同一个微信号进行登录授权,那么这些小程序中的 unionid 都是相同的。

【注意】用户的unionid只有在用户将多个应用绑定到同一个微信开放平台账号下时才会生成。因此,如果用户没有绑定多个应用,那么小程序将无法获取用户的unionid。

  • codecode 是用户登录凭证,由微信服务器颁发给小程序。在用户授权登录后,小程序可以通过调用微信登录接口获取用户的 code。然后,通过code向微信服务器请求用户的 openidsession_key 等信息。

【注意】每个code只能使用一次,且有效期为5分钟。因此,在使用code进行登录时,需要及时将其转换成用户的 openidsession_key 等信息,以免出现code过期的情况。

openidunionidcode 是微信小程序登录授权中非常重要的三个参数,了解这些参数的作用和用法,有助于开发者更好地设计和开发小程序登录授权功能。

在这里插入图片描述

  1. 通过wx.login()获取code。

  2. 将这个code发送给后端,后端会返回一个token,这个token将作为你身份的唯一标识。

  3. 将token通过wx.setStorageSync()保存在本地存储。

  4. 用户下次进入⻚面时,会先通过wx.getStorageSync() 方法判断token是否有值,如果有值,则可以请求其它数据,如果没有值,则进行登录操作。

微信小程序开发流程介绍就先到这里了,有任何疑问欢迎给我留言,后续会持续更新相关教程,请小伙伴耐心等待,也可关注我的公众号【大数据与云原生技术分享】加群交流或私信交流技术~

标签:code,登录,微信,流程,程序开发,程序,用户,开发
From: https://www.cnblogs.com/liugp/p/17300695.html

相关文章

  • Spring Cloud Admin添加微信通知
    SpringCloud发送微信消息推送参考https://blog.csdn.net/qq_44697754/article/details/128035736。  SpringCloudAdmin要增加微信通知,需要继承AbstractStatusChangeNotifier类,在doNotify方法按照模板发送消息。 AdminServe添加依赖:<dependency><groupId>common......
  • Yarn运行流程
    用户向ResourceManager中提交应用程序,其中包括ApplicationMaster程序。ResourceManager为ApplicationMaster分配一个Container(分配后Container由NodeManager创建),然后NodeManager在Container中运行ApplicationMaster。ApplicationMaster首先向ResourceManager注册,App......
  • python基础篇: python中的流程控制,你都了解吗?
    在之前的文章中大致的介绍过python中的流程控制语句,今天通过一些案例来详细了解一下python中的流程语句。目前python中流程控制语句,包含如下,如有遗漏欢迎留言补充。条件判断语句在python中条件判断语句包括了if、else、elif,还有在python3.10的版本新增了match-case语句。i......
  • 2023应用上架谷歌商店流程
    海外开发基础环境有可以科学的环境手机要支持/安装谷歌框架有外币信用卡/借记卡-visa之类的注册谷歌账号,开启两步验证-后面开也ok最好使用GmailPS:最好一卡一号注册GooglePlay开发者账号注册开发者网站Gp管理中心帮助网站开发者政策中心进入注册开发者网站,按需选......
  • 微信算账机器人
    微信算账机器人4月6日消息,当前,随着人工智能、高性能计算、5G等领域快速发展,数字化、智能化、多样化的应用不断涌现,对算网基础设施数据计算处理及网络传输能力提出了更高的需求。作为人工智能工程化的重要组成部分,人工智能研发运营体系(MLOps)面向AI模型全生命周期建设标准化、......
  • 最新中国福彩分析大数据分析大师拥有双色球数据展示微信小程序源码支持双色球数据分析
    demo软件园每日更新资源,请看到最后就能获取你想要的: 1.最新中国福彩分析大数据分析大师拥有双色球数据展示微信小程序源码支持双色球数据分析多个接口福彩大数据分析小程序,数据来自于中国福利彩票 拥有双色球数据展示 双色球数据分析多个接口 数据有每日奖金和往期记录......
  • flask框架04 导出项目 local flask生命执行流程 wtforms
    今日内容详细目录今日内容详细1请求上下文分析(源码:request原理)1.1导出项目的依赖1.2函数和方法1.3threading.local对象1.4偏函数1.5flask整个生命执行流程(1.1.4版本为例)2wtforms(了解)1请求上下文分析(源码:request原理)1.1导出项目的依赖#之前pipfreeze>requ......
  • 【web 开发基础】PHP 的流程控制之嵌套(巢状)条件分支结构 -PHP 快速入门 (15)
    嵌套条件分支结构嵌套条件分支结构,也称为巢状条件分支结构。其实就是将if语句进行嵌套,即是在if或者else后面的语句块中又包含if语句。if语句可以无限层第嵌套在其他if语句中,这给程序的不同部分的条件执行提供了充分的弹性,是程序设计中经常使用的技术。其语法格式如下所示:if(表达式1......
  • linux系统升级/更新OpenSSL版本操作流程记录
    问题描述:有时OpenSSL版本过老升级,或者需要更新OpenSSL版本1.登录linux系统后输入opensslversion查看现在使用的版本我的输入后版本信息为:OpenSSL1.1.1gFIPS 21Apr2020,可以看到是一年前更新版本,是有些老。2.登录openssl官网查看最新版本。登录https://www.openssl.org......
  • 小程序开发系统的四个显著特点,让你日进斗金
     在当下的时代,小程序开发系统在我们的生活中扮演着一个非常重要的角色,可以极大程度地满足我们的消费需求,让许多商家纷纷加入其中。那么它有什么特点呢?今天名锐讯动为大家介绍小程序开发系统的四个显著特点。 1.成本低。对于新手以及一些成本预算不足的人来说,开发小程序需要付......