uni-app(微信小程序) 根据小程序页面路径(可带参数) 生成二维码、分享码

小程序的官方文档有生成小程序码的API

微信官方文档 小程序 看文档点这里

在这里插入图片描述

  1. 第一个获取小程序码,就是根据你要通过二维码打开的页面路径生成一个小程序码,且这个小程序码是永久的
    在这里插入图片描述
    其实文档内也说明了,很少用到。即使需要生成这样的小程序码,可以去微信公众平台的小程序管理后台生成,还方便。
    在这里插入图片描述
    在这里插入图片描述

重点说如何使用获取不限制的小程序码(我的使用场景是uniapp的框架,微信小程序根据用户ID生成分享码,并与被分享者建立关系,所以需要带参数)

  1. 调用方式 也就是接口地址(地址后面的access_token第三点说如何获取)
POST https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=ACCESS_TOKEN
  1. 参数
scene  必传  // 这个就是你需要通过页面传的参数
page  非必传  // 默认就是主页 例如 pages/index/index,
			//根路径前不要填加 /,不能携带参数
			//(参数请放在scene字段里),如果不填写这个字段,默认跳主页面

还有别的参数可以看文档根据实际需求添加

3. access_token的获取

GET https://api.weixin.qq.com/cgi-bin/token 

在这里插入图片描述
三个必填参数

  1. grant_type 固定传 client_credential
  2. appid 和secret 去小程序的公众平台 --> 开发管理 --> 开发设置 获取
    在这里插入图片描述
拿到 appid 和 secret 之后就可以通过接口获取access_token 用GET请求。这个可以交给后端也可以前端自己去获取
// 获取 access_token
getAccessToken(){
	uni.request({
		method: "GET",
		url: `https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=${appid}&secret=${secret}`,
		success:(result) =>{
			let access_token = result.data.access_token
			// 获取到 access_token 后 获取二维码
			this.getQrCode(access_token)
		}
	})
}
// 获取二维码
getQrCode(token){
	// 注意 access_token 参数是必须放在url后面 其余参数 要在data里面
	let path = 'pages/index/index'
	uni.request({
		method: "POST",
		responseType: 'arraybuffer', // 注意一定要加 不然返回的Buffer流会乱码 导致无法转base64
		url: `https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=${token}`,
		data: {
			page: path, // 需要打开的页面路径
			scene: this.userid // 这个是需要传递的参数
		},
		success:(result) =>{
			// 拿到buffer流 通过wx.arrayBufferToBase64 转成base64 在页面展示
			// 如果不加请求时 responseType: 'arraybuffer' 则会转码失败
			this.bufferImg = "data:image/png;base64," + wx.arrayBufferToBase64(result.data);
		},
	})
}
// template 部分
<image :src="bufferImg" style="width: 200px;height: 200px"></image>



获取access_token 成功回调

在这里插入图片描述

获取小程序码成功的回调 这是接口的预览可直接看见二维码,但是如果要展示在页面上就需要转码

在这里插入图片描述

打开页面的参数如何接收 (跟普通路由页面跳转时的参数获取一样)

在这里插入图片描述

以上就是我实践过程的总结 期间踩了蛮多的坑 现在整理下 希望你们别再踩坑了

https://api.weixin.qq.com开头的接口调用发不到正式环境会不显示,是小程序合法域名的问题,且这个不能在小程序后台配置,所以这两个只能放在后端去调用

在这里插入图片描述

页面展示的小程序码是没有办法直接分享出去的,需要先保存在本地相册之后再出去分享,由于图片不是本地图片,就用不了小程序的API去保存,下面是我用的方法

  1. 第一步获取相册权限 不用改,可以直接用
saveAlbum() { //获取权限保存相册
	uni.getSetting({ //获取用户的当前设置
		success: (res) => {
			// console.log("获取权限",res);
			if (res.authSetting['scope.writePhotosAlbum']) { //验证用户是否授权可以访问相册
				this.saveImageToPhotosAlbum();
			} else {
				uni.authorize({ //如果没有授权,向用户发起请求
					scope: 'scope.writePhotosAlbum',
					success: () => {
						this.saveImageToPhotosAlbum();
					},
					fail: () => {
						uni.showToast({
							title: "请打开保存相册权限,再点击保存相册分享",
							icon: "none",
							duration: 3000
						});
						setTimeout(() => {
							uni.openSetting({ //调起客户端小程序设置界面,让用户开启访问相册
								success: (res2) => {
									// console.log(res2.authSetting)
								}
							});
						}, 3000);
					}
				})
			}
		}
	})
},
  1. 保存图片至相册
saveImageToPhotosAlbum() {
	// 下面注释掉的是把base64 去掉头部,我们可以直接使用没有添加头的数据 所以就可以不用再去转
	// this.maskData=this.bufferImg.replace(/^data:image\/\w+;BASE64,/, "");//去掉data:image/png;base64,
	// 保存图片的名字 可以写死 也可以写成动态的
	let filePath = wx.env.USER_DATA_PATH + `/qrcode.png`;
	uni.getFileSystemManager().writeFile({
		filePath: filePath, //创建一个临时文件名
		data: this.maskData, //写入的文本或二进制数据
		encoding: 'base64', //写入当前文件的字符编码
		success: res => {
			uni.saveImageToPhotosAlbum({
				filePath: filePath,
				success: function(res2) {
					uni.showToast({
						title: '保存成功,请从相册选择再分享',
						icon: "none",
						duration: 5000
					})
				},
				fail: function(err) {
					// console.log(err.errMsg);
				}
			})
		},
		fail: err => {
			//console.log(err)
		}
	})
},
<think>嗯,用户想找关于如何在STM32F407VET6上配置LAN8720网络芯片的资料或教程。首先,我需要回顾一下STM32系列的网络配置,特别是F4系列的以太网接口。记得STM32F4通常使用MAC和PHY芯片,而LAN8720是一个常用的PHY芯片。用户提到的芯片是STM32F407VET6,所以需要确认这个型号是否支持以太网外设。根据引用[2],STM32F4系列确实有以太网接口,所以没问题。 接下来,用户需要配置LAN8720,这涉及到硬件连接和软件配置。硬件方面,需要检查引脚连接,比如RMII接口的时钟、数据线,以及LAN8720的地址配置。根据引用[1],示例中使用的是地址1,所以用户可能需要设置相应的引脚电平。软件方面,CubeMX配置是关键,包括启用ETH外设,选择RMII模式,配置PHY地址,以及时钟设置。这里要提醒用户注意时钟源,因为LAN8720需要外部时钟输入,通常是25MHz,同时STM32的ETH时钟需要正确配置,可能来自外部晶振或内部PLL。 然后,生成后需要初始化LwIP协议栈,这部分在引用[1]的示例中已经实现。用户可能需要参考示例代中的udp_echoserver.c来处理数据收发。另外,PHY芯片的驱动初始化也很重要,比如检查LAN8720的状态寄存器,确保连接正常。引用[2]提到不同型号的STM32可能有不同的配置方法,所以需要确认F407VET6的具体寄存器设置。 可能遇到的问题包括PHY地址配置错误、时钟配置不正确导致通信失败,以及硬件连接问题。建议用户仔细检查原理图,使用逻辑分析仪或示波器检查信号。此外,CubeMX的配置步骤需要详细说明,比如在ETH配置中选择RMII,正确设置PHY地址为1,以及配置引脚功能。 用户还可能关心示例代的获取,引用[1]中的项目地址提供了基于CubeMX和FreeRTOS的示例,这可以作为起点。同时,MicroPython的相关内容在引用[3]中,但用户的问题主要涉及C语言和CubeMX配置,所以可能不需要深入MicroPython部分,除非用户有特殊需求。 总结回答结构:先介绍硬件配置要点,然后分步骤讲解CubeMX配置,接着是代实现部分,最后是常见问题及解决方法。需要确保所有行内公式用$...$,独立公式用$$...$$,并且引用文献正确标注。生成的相关问题可能涉及硬件连接细节、CubeMX配置步骤、PHY初始化代、调试技巧和LwIP协议栈的应用。</think>### STM32F407VET6配置LAN8720方法详解 #### 一、硬件配置要点 1. **引脚连接** - LAN8720通过RMII接口与STM32F407VET6连接,关键引脚包括: $$ \text{RMII\_REF\_CLK} \rightarrow PA1,\quad \text{RMII\_MDIO} \rightarrow PA2 $$ $$ \text{RMII\_TXD0} \rightarrow PG13,\quad \text{RMII\_CRS\_DV} \rightarrow PA7 $$ - PHY地址由`PHYAD0`引脚电平决定,默认地址为$0$或$1$[^1] 2. **时钟配置** - LAN8720需外部提供$25\text{MHz}$时钟信号 - STM32的ETH时钟需配置为$50\text{MHz}$(通过PLL或外部晶振) #### 二、CubeMX配置步骤 1. **启用ETH外设** - 在`Connectivity`中选择`ETH` - 模式选择`RMII`,勾选`Auto Negotiation` ```c // CubeMX自动生成的ETH初始化片段 heth.Instance = ETH; heth.Init.AutoNegotiation = ETH_AUTONEGOTIATION_ENABLE; heth.Init.PhyAddress = 0x01; // PHY地址需与实际硬件匹配 ``` 2. **PHY参数设置** - 在`Parameter Settings`中配置: - `PHY Address`设为$1$(根据硬件设计) - `Speed`选择`100Mbps` - `Mode`选择`Full-duplex` 3. **时钟树配置** - 确保ETH时钟源为$50\text{MHz}$ - 通过PLL配置实现: $$ \text{HSE}(25\text{MHz}) \xrightarrow{\times 4} \text{PLL\_Q} \rightarrow 100\text{MHz} \xrightarrow{/2} 50\text{MHz} $$ #### 三、代实现关键点 1. **PHY初始化验证** ```c uint32_t phyreg; HAL_ETH_ReadPHYRegister(&heth, PHY_BSR, &phyreg); if(phyreg & PHY_LINKED_STATUS) { // 连接状态正常 } ``` 2. **LwIP协议栈集成** - 引用示例中的网络协议栈初始化方法: ```c void MX_LWIP_Init(void) { tcpip_init(NULL, NULL); udp_echoserver_init(); // UDP服务初始化 } ``` #### 四、常见问题解决 1. **PHY无法识别** - 检查`PHYAD0`引脚电平(地址$0$对应低电平,$1$对应高电平) - 用示波器测量`RMII_REF_CLK`是否有时钟信号 2. **数据传输失败** - 验证内存配置: ```c #define ETH_RX_BUF_SIZE 1536 __attribute__((section(".RxArraySection"))) uint8_t Rx_Buff[ETH_RX_BUF_SIZE]; ``` #### 五、参考示例代 推荐使用[引用1]提供的完整工程示例,包含: - CubeMX配置文件(`.ioc`) - LwIP协议栈配置 - UDP通信实现(`udp_echoserver.c`) 项目地址:https://gitcode.com/open-source-toolkit/7b166
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值