当前位置: 首页 > news >正文

Vue开发微信公众号上传图片

 处理思路:

  1. 从服务器获取微信配置参数,进行微信配置
  2. 选择本地图片,获取图片base64输出
  3. 将base64图片转化为文件上传

 

关键代码:

1.获取配置与选择本地图片输出

import http from './http'
import api from './api'
import wx from "weixin-js-sdk";
export default {getConfig() {http.get(api.getWechatConfig, {url: window.location.href}).then(res => {if (res.code == 0) {var config = res.data;wx.config({appId: config.appId, // 必填,公众号的唯一标识timestamp: config.timestamp, // 必填,生成签名的时间戳nonceStr: config.nonceStr, // 必填,生成签名的随机串signature: config.signature, // 必填,签名jsApiList: ["checkJsApi", "chooseImage", "previewImage", "getLocalImgData"]});}});},selectImg(callback) {wx.chooseImage({count: 1,success(res) {var localid = res.localIds[0];wx.getLocalImgData({localId: localid,success(res) {var localData = res.localData;if (localData.indexOf("data:image") == 0) {localData = localData.replace("jgp", "jpeg");} else {localData = "data:image/jpeg;base64," + localData.replace(/\n/g, "");}callback(localData);}});}});}
}

2.将base64图片转为Bob

dataURItoBlob(dataURI) {var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0]; // mime类型var byteString = atob(dataURI.split(',')[1]); //base64 解码var arrayBuffer = new ArrayBuffer(byteString.length); //创建缓冲数组var intArray = new Uint8Array(arrayBuffer); //创建视图for (var i = 0; i < byteString.length; i++) {intArray[i] = byteString.charCodeAt(i);}return new Blob([intArray], {type: mimeString});
}

 3.使用multipart/form-data上传

var data = new FormData();
var bob = util.dataURItoBlob(localData);
data.append("hold_pic", bob);

记录于 2020-06-21

http://www.zskr.cn/news/5934.html

相关文章:

  • 栈的妙用:如何优雅地处理括号匹配难题 (C语言版)
  • 食品包装 AI 视觉检测技术:原理、优势与数据应用解析
  • 电流探头的常见应用场景
  • PC桌面应用开发选择
  • 无需复杂正则:SLS 新脱敏函数让隐私保护更简单高效
  • PLC结构化文本设计模式——适配器模式(Adapter Pattern)
  • 深入浅出 Java 多线程:从线程生命周期到并发安全
  • 实用指南:LINUX910 CENTOS8 新建虚拟机;重设root密码/时间同步
  • 零基础学习PYthon记录
  • Grafana 中文入门教程 | 构建你的第一个仪表盘
  • Topaz Photo AI Pro 4.0.4 AI图片智能降噪
  • Edge浏览器网页长截图
  • C++多线程编程—线程控制、同步与互斥详解
  • mac 的任务栏 Windows-Style Taskbar For macOS
  • 快手Java一面
  • 想找Axure替代?这6个原型设计工具值得一试
  • 实用指南:javaweb HTML基本介绍/常见标签
  • 文档处理控件Aspose.Words教程:在 C# 中将 Markdown 转换为 PDF
  • docker容器mysql导入sql文件
  • IDE工具RAD Studio 13 Florence重磅发布:64 位 IDE + AI 组件全面升级!
  • 移动安全框架(MobSF)静态分析入门指南
  • CRMEB标准版PHP批量发货功能深度解析
  • 模型上下文协议(Model Context Protocol,MCP)
  • 大华设备视频平台EasyCVR视频分析设备平台双轨视频数据存储方案全解读
  • AI音乐创作新突破:ACE-Step模型开启放克音乐智能生成时代
  • macOS Sequoia 15.7 (24G222) Boot ISO 原版可引导镜像下载
  • Nginx 安装过程
  • mysql数据库服务主从复制实现(基于position)
  • 海量接入、毫秒响应:易易互联携手阿里云构筑高可用物联网消息中枢
  • C++ std::list