微信小程序请求二维码:用户点击按钮生成带参二维码
来源:互联网 发布:前端js面试题及答案 编辑:程序博客网 时间:2024/06/04 19:16
目标:
请求二维码并展示
步骤:
用户点击按钮生成二维码
步骤:
1、微信小程序往后台请求二维码
2、后台(java/php) 根据微信小程序信息往微信端请求tonken
3、后台得到tonken后往微信端请求二维码图片
4、后台得到图片后保存在服务器上,将路径返回给微信小程序
5、微信小程序得到路径后,根据路径下载图片
6、下载图片成功后再保存至本地
7、保存成功后将路径给予image标签里面展示
代码:
wxml
<image class="scanimg" src="{{filePath}}" bindtap="getAgain"></image>
<button type="primary" bindtap="primary">点击生成二维码</button>
s代码
primary:function (e) {
var _url = '后台地址';
wx.request({
url: _url,
//请求报文体
data: [{
id: agentCode
}],
method: 'POST',
header: {
'content-type': 'application/json'
},
success: function (res) {
//为00时表示成功,得到二维码的地址
if (res.data.code == '00') {
console.log("成功")
//下载二维码
wx.downloadFile({
url: res.data.body[0].URL,
success: function (res) {
//如果二维码中的id为固定值可以将图片保存到本地,否则不用保存
wx.saveFile({
tempFilePath: res.tempFilePath,
success: function (res) {
console.log("保存成功")
_that.setData({
filePath: res.savedFilePath
})
console.log(res.savedFilePath)
try {
//id为定值,则将保存的地址存入缓存,非定值则只需要setData就行
wx.setStorageSync('filePath', res.savedFilePath)
} catch (e) {
console.log(e)
}
},
fail: function (res) {
console.log("保存失败")
console.log(res)
}
})
}, fail: function (res) {
util.msg("错误", "通讯失败")
console.log(res)
}
})
} else {
console.log("错误")
util.msg("错误", res.data.msg)
}
},
fail: function () {
util.msg("错误", "通讯失败")
console.log(res)
}
})
}
java端代码
// 访问微信后台的URL
String URL = systemConfig.getString("LoginOrRegisterUrl");
// 请求类型
String grant_type = systemConfig.getString("grant_type");
// 第三方用户唯一凭证密钥
String secret = systemConfig.getString("secret");
// 第三方用户唯一凭证
String appId = systemConfig.getString("appid");
// 请求token时用到的URL
String tokenUrl = systemConfig.getString("tokenUrl");
// 向微信后台请求获取token
String sendGet = HttpClientConnectionManager.sendGet(
tokenUrl, "grant_type=" + grant_type
+ "&secret=" + secret + "&appid="
+ appId + "");
System.out.println(sendGet);
JSONObject json = JSONObject.fromObject(sendGet);
access_token = json.get("access_token").toString();
if (access_token == null) {
//没有token 则返回错误码和错误信息
agentDTO.setCode("0002");
agentDTO.setDesc("获取tokenId失败");
return agentDTO;
}
System.out.println(access_token);
// 访问微信后台带的json参数
Map<String, Object> map = new HashMap<String, Object>();
map.put("path", "pages/register");//你二维码中跳向的地址
map.put("width", "430");//图片大小
JSONObject json = JSONObject.fromObject(map);
HttpClientConnectionManager.httpPostWithJSON(URL
+ access_token, json.toString(), id + "max");
// 返回给前端的后台服务器文件读取路径
String downloadUrl = systemConfig
.getString("agentImgDownloadUrl")
+ id
+ "max"
+ "/";
// 返回给前端的后台服务器文件下载路径
String downloadfileUrl = downloadUrl + id + "max" + ".jpg";
agentResView.setURL(downloadfileUrl);
agentDTO.setAgentResView(agentResView);
agentDTO.setCode("00");
agentDTO.setDesc("成功");
return agentDTO;
tip
1、这是申请一张二维码的代码,申请多张可以用for或者其他的方法
2、当id为定量时,每次点击按钮判断filePath缓存是否存在,存在则直接取值展示,不存在则向后台请求二维码 。
- 微信小程序请求二维码:用户点击按钮生成带参二维码
- 【微信小程序 四】二维码生成/扫描二维码
- 微信小程序----获取带参二维码
- 小程序二维码生成器,带参数二维码生成
- 在线生成小程序二维码,在线制作带参数微信小程序二维码
- java微信小程序参数二维码生成带背景图加字体
- 小程序带参数二维码快速生成
- Android 点击生成二维码
- 微信小程序二维码如何生成?
- 微信小程序动态生成二维码
- 生成微信小程序二维码 PHP
- 带图片二维码生成
- java生成带二维码
- java生成带二维码
- zxing 二维码、带logo二维码生成
- 普通二维码和带图片二维码生成
- ZXing生成条形码、二维码、带logo二维码
- java程序生成二维码
- C++抽象编程——字符串与整数之间的相互转换详解
- javaScript高级程序设计学习笔记(3下)
- java简单链表实现
- Python Treelib 多叉树 数据结构 中文使用帮助文档
- 清除应用缓存
- 微信小程序请求二维码:用户点击按钮生成带参二维码
- Dao设计模式
- JAVA中clone方法详解
- 启动hive时报错UnsupportedClassVersionError
- html中的image标签和jquery选择器
- 支付宝 微信 内购 支付
- TCP协议和UDP协议的区别
- linux镜像下载网站
- 阿里巴巴 Java 开发手册评述