关于微信小程序获取小程序码并接受buffer流保存为图片的方法


Posted in Javascript onJune 07, 2019

前言

昨天因为小程序功能要获取小程序程序码,看了微信文档爬了好多坑。(留一下记录以防后面被坑)

操作

因为我获取到了微信那里的图片的图片流一直不知道怎么处理,今天总算找到相关文档,解决了。因为数据流不能直接传给前端,只好把buffer流转成图片保存在服务器上,没办法啊~

废话不多说上代码

public static string Api_Post(string postUrl, string postData, WebHeaderCollection header = null,bool isPic=false)

 {
      Stream outstream = null;
      Stream instream = null;
      StreamReader sr = null;
      HttpWebResponse response = null;
      HttpWebRequest request = null;
      Encoding encoding = Encoding.UTF8;
      byte[] data = encoding.GetBytes(postData);
      // 准备请求...
      try
      {
        // 设置参数
        request = WebRequest.Create(postUrl) as HttpWebRequest;
        CookieContainer cookieContainer = new CookieContainer();
        request.CookieContainer = cookieContainer;
        request.AllowAutoRedirect = true;
        request.Method = "POST";
        request.ContentType = "application/x-www-form-urlencoded";
        if (header != null) request.Headers = header;
        request.ContentLength = data.Length;
        outstream = request.GetRequestStream();
        outstream.Write(data, 0, data.Length);
        outstream.Close();
        //发送请求并获取相应回应数据
        response = request.GetResponse() as HttpWebResponse;
        //直到request.GetResponse()程序才开始向目标网页发送Post请求
        instream = response.GetResponseStream();

        if (isPic)
        {
          byte[] tt = StreamToBytes(instream);//将数据流转为byte[]
          System.IO.File.WriteAllBytes(HttpContext.Current.Server.MapPath("~/WxCode.jpg"), tt);
          WxQRCodeModel model = new WxQRCodeModel();
          model.data = "192.168.1.216:80/WxCode.jpg";
          model.errcode = 0;
          string content = Config.js.Serialize(model);
          string err = string.Empty;
          return content;
        }
        else
        {
          sr = new StreamReader(instream, encoding);
          //返回结果网页(html)代码
          string content = sr.ReadToEnd();
          string err = string.Empty;
          return content;
        }

      }
      catch (Exception ex)
      {
        if (isPic)
        {
          sr = new StreamReader(instream, encoding);
          //返回结果网页(html)代码
          string content = sr.ReadToEnd();
          string err = string.Empty;
          return content;
        }
        else
        {
          string err = ex.Message;
          return string.Empty;
        }
      }
    }

因为是instream接受到微信接口那里发送过来的数据流,就在instream那里处理,把数据流转换为byte[]数组,然后依靠File的WriteAllBytes方法把转换OK的byte[]数组转换为图片存放在服务器上,然后把图片路径交给model。

///将数据流转为byte[]
    public static byte[] StreamToBytes(Stream stream)
    {
      List<byte> bytes = new List<byte>();
      int temp = stream.ReadByte();
      while (temp != -1)
      {
        bytes.Add((byte)temp);
        temp = stream.ReadByte();
      }
      return bytes.ToArray();
    }

结尾

最近才接触到微信小程序开发,emmmm。觉得自己摸鱼摸得好厉害,不过终于把坑爬出来,特别开心。哈哈哈~以后要多多写开发记录。上班期间码得很随意

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
JavaScript 快捷键设置实现代码
Mar 13 Javascript
关于在IE下的一个安全BUG --可用于跟踪用户的系统鼠标位置
Apr 17 Javascript
jQuery仿Flash上下翻动的中英文导航菜单实例
Mar 10 Javascript
jQuery实现鼠标经过事件的延时处理效果
Aug 20 Javascript
返回函数的JavaScript函数
Jun 14 Javascript
vue.js+Echarts开发图表放大缩小功能实例
Jun 09 Javascript
微信小程序实现鼠标拖动效果示例
Dec 01 Javascript
使用vue-router beforEach实现判断用户登录跳转路由筛选功能
Jun 25 Javascript
vue-loader中引入模板预处理器的实现
Sep 04 Javascript
javascript实现文字跑马灯效果
Jun 18 Javascript
ssm+vue前后端分离框架整合实现(附源码)
Jul 08 Javascript
VueCli生产环境打包部署跨域失败的解决
Nov 13 Javascript
vue集成kindeditor富文本的实现示例代码
Jun 07 #Javascript
Vue使用Proxy监听所有接口状态的方法实现
Jun 07 #Javascript
你了解vue3.0响应式数据怎么实现吗
Jun 07 #Javascript
ES6小技巧之代替lodash
Jun 07 #Javascript
vue+element 模态框表格形式的可编辑表单实现
Jun 07 #Javascript
vue-cli3项目展示本地Markdown文件的方法
Jun 07 #Javascript
Element实现表格分页数据选择+全选所有完善批量操作
Jun 07 #Javascript
You might like
解析PHP 使用curl提交json格式数据
2013/06/29 PHP
sina的lightbox效果。
2007/01/09 Javascript
解决表单中第一个非隐藏的元素获得焦点的一个方案
2009/10/26 Javascript
ASP 过滤数组重复数据函数(加强版)
2010/05/31 Javascript
基于jquery 的一个progressbar widge
2010/10/29 Javascript
对setInterval在火狐和chrome切换标签产生奇怪的效果之探索,与解决方案!
2011/10/29 Javascript
js转义字符介绍
2013/11/05 Javascript
判断复选框是否被选中的两种方法
2014/06/04 Javascript
javascript初学者常用技巧
2014/09/02 Javascript
Node.js中的process.nextTick使用实例
2015/06/25 Javascript
jQuery实现摸拟alert提示框
2016/05/22 Javascript
JavaScript易错知识点整理
2016/12/05 Javascript
JS去除重复并统计数量的实现方法
2016/12/15 Javascript
jQuery插件Echarts实现的渐变色柱状图
2017/03/23 jQuery
vue 挂载路由到头部导航的方法
2017/11/13 Javascript
Vue页面骨架屏注入方法
2018/05/13 Javascript
vue-cli在 history模式下的配置详解
2019/11/26 Javascript
Python跳出循环语句continue与break的区别
2014/08/25 Python
Python单例模式实例详解
2017/03/01 Python
Python实现PS图像调整黑白效果示例
2018/01/25 Python
PyQt5每天必学之带有标签的复选框
2018/04/19 Python
Python实现计算对象的内存大小示例
2019/07/10 Python
Python实现简单的列表冒泡排序和反转列表操作示例
2019/07/10 Python
Python中typing模块与类型注解的使用方法
2019/08/05 Python
解决pycharm中导入自己写的.py函数出错问题
2020/02/12 Python
基于python实现音乐播放器代码实例
2020/07/01 Python
如何解决安装python3.6.1失败
2020/07/01 Python
用React加CSS3实现微信拆红包动画效果
2017/03/13 HTML / CSS
铭万公司.net面试题笔试题
2014/07/20 面试题
后勤采购员岗位职责
2013/12/19 职场文书
公务员培训自我鉴定
2014/02/01 职场文书
班级读书活动总结
2014/06/30 职场文书
中学生社区服务活动报告
2015/02/05 职场文书
公司禁烟通知
2015/04/23 职场文书
2016简历自荐信优秀范文
2016/01/29 职场文书
七年级作文之游记
2019/12/11 职场文书