uniapp生成微信小程序二维码

文章目录

一、获取不限制的小程序码

获取不限制的小程序码一般情况下是由后端来提供接口的

官方文档地址:获取不限制的小程序码

请求事例:POST https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=ACCESS_TOKEN

1、第一步:需要先获取ACCESS_TOKEN

官方文档地址:获取接口调用凭据

以下代码注意:需要补充自己的 appid 以及 微信小程序密钥

html 复制代码
<template>
	<view class="" @click="getAccessToken">获取Access_Token</view>
</template>
<script>
export default{
	data(){
		return{
			access_token: "",
		}
	},
	mounted(){},
	methods:{
		getAccessToken() {
			let that = this
			uni.request({
				// https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=你的APPID&secret=你的微信小程序密钥
				url: 'https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=你的APPID&secret=你的微信小程序密钥',
				method: "GET",
				success(res) {
					that.access_token = res.data.access_token
				},
				fail(err) {
					console.log(err)
				}
			})
		},
	}
</script>
2、第二步:获取微信小程序二维码

如果微信小程序没上线之前可以先把 check_path 改为 false 可以生成

注意 wx.arrayBufferToBase64 是微信小程序的方法 官方文档

html 复制代码
<template>
	<view class="" @click="getQRCode">获取二维码</view>
</template>
<script>
	export default {
		data() {
			return {
				image: ""
			}
		},
		mounted() {
			getQRCode() {
				let that = this
				uni.request({
					url: `https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=${this.access_token}`,
					responseType: "arraybuffer",
					method: "POST",
					data: {
						// 更多参数请看官方文档
						"page": "pages/homepage/index", // 默认是主页,页面 page
						"scene": "id=10", // 参数
						"check_path": false, // 默认是true,检查page 是否存在
						"env_version": "trial" // 要打开的小程序版本。正式版为 "release",体验版为 "trial",开发版为 "develop"。默认是正式版。
					},
					success(res) {
						// 该接口返回的是 图片二进制 数据
						const arrayBuffer = new Uint8Array(res.data)
						const base64 = wx.arrayBufferToBase64(arrayBuffer)
						that.image = `data:image/jpeg;base64,${base64}`
					},
					fail(err) {
						console.log(err)
					}
				})
			},
		},
		methods: {

		}
	}
</script>
html 复制代码
<!-- 
errcode: 41030
errmsg: "invalid page rid: 667d1102-546f773b-0d82ff0b"
page路径不正确,需要先提交发布一版微信小程序并且存在page路径
-->

<!-- 
errcode: 40169
errmsg: "invalid length for scene, or the data is not json string rid: 667d11cf-3d9f72b6-5542f406"
scene 不合法
最大32个可见字符,只支持数字,大小写英文以及部分特殊字符:!#$&'()*+,/:;=?@-._~,其它字符请自行编码为合法字符(因不支持%,中文无法使用 urlencode 处理,请使用其他编码方式)
注意:也不允许为空
-->

二、获取小程序码

该接口用于获取小程序码,适用于需要的码数量较少的业务场景。通过该接口生成的小程序码,永久有效,有数量限制

官方文档地址:获取小程序码

1、第一步:需要先获取ACCESS_TOKEN

与上面一致复制即可

2、第二步:获取微信小程序二维码
html 复制代码
<template>
	<view class="" @click="getQRCode">
		获取二维码
	</view>
	<img :src="image" alt="" style="width: 400rpx;height: 400rpx;" />
</template>

<script>
	export default {
		data() {
			return {
				image: ""
			}
		},
		mounted() {},
		methods: {
			getQRCode() {
				let that = this
				uni.request({
					url: `https://api.weixin.qq.com/wxa/getwxacode?access_token=${this.access_token}`,
					responseType: "arraybuffer",
					method: "POST",
					data: {
						"path": "pages/homepage/index",
						"env_version": "trial"
					},
					success(res) {
						const arrayBuffer = new Uint8Array(res.data)
						const base64 = wx.arrayBufferToBase64(arrayBuffer)
						that.image = `data:image/jpeg;base64,${base64}`
					},
					fail(err) {
						console.log(err)
					}
				})
			},
		}
	}
</script>

三、扫普通链接二维码打开小程序

不支持个人类型小程序开启此功能

微信公众平台

扫普通链接二维码打开小程序:说明文档

操作:开发管理 > 开发设置 > 扫普通链接二维码打开小程序 > 点击添加


1、协议以及大小写

按照自己的场景来选择吧

一般情况选 https小写

2、二维码规则

其实就是一个 地址链接 官方文档写的很清楚了

例如:原有二维码链接地址是:https://www.myproject.com?id=1 我们就可以填写 https://www.myproject.com

前缀占用规则选择 不占用

3、校验文件

注意:下载完的校验文件,需要上传到服务器指定位置的目录下

官方文档举例:二维码规则为:https://www.qq.com/weixin/miniprogran

下载完的校验文件放在:https://www.qq.com/weixin

4、小程序功能页面选择你扫码要打开的页面就可以了
5、测试范围根据场景自己选择:正式版、体验版、开发版
6、测试链接:填写一个完整的链接地址,包括参数。

最后:发布二维码规则之前需要先发布微信小程序。

相关推荐
anyup2 小时前
支持鸿蒙!开源三个月,uView Pro 开源库近期更新全面大盘点,及未来计划
前端·vue.js·uni-app
阿斌_bingyu7096 小时前
uniapp实现android/IOS消息推送
android·ios·uni-app
茶憶9 小时前
UniApp RenderJS中集成 Leaflet地图,突破APP跨端开发限制
javascript·vue.js·uni-app
云起SAAS18 小时前
名字姓名起名打分评分抖音快手微信小程序看广告流量主开源
微信小程序·小程序·ai编程·看广告变现轻·名字姓名起名打分评分
2501_915918411 天前
移动端 HTTPS 抓包实战,多工具组合分析与高效排查指南
数据库·网络协议·ios·小程序·https·uni-app·iphone
雪芽蓝域zzs1 天前
uni-app 将 base64 图片编码转为 Blob 本地文件路径
网络协议·udp·uni-app
星光一影1 天前
陪诊陪检系统源码,陪诊小程序,陪诊APP,陪诊服务,家政上门系统,居家护理陪护源码
mysql·小程序·uni-app·php
Qlittleboy1 天前
uniapp里 rich-text 里的img图片如何控制最大宽度
uni-app
阿奇__1 天前
uniapp h5 app 小程序获取当前定位
小程序·uni-app
*小雪1 天前
uniapp写H5授权登录及分享,返回到目标页面
开发语言·javascript·uni-app