关于微信小程序获取小程序码并接受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 相关文章推荐
动态调用CSS文件的JS代码
Jul 29 Javascript
javascript实现鼠标移到Image上方时显示文字效果的方法
Aug 07 Javascript
js实现的黑背景灰色二级导航菜单效果代码
Aug 24 Javascript
JavaScript判断数字是否为质数的方法汇总
Jun 02 Javascript
微信小程序 wxapp视图容器 view详解
Oct 31 Javascript
浅谈jQuery中的$.extend方法来扩展JSON对象
Feb 12 Javascript
js实现时间轴自动排列效果
Mar 09 Javascript
angular directive的简单使用总结
May 24 Javascript
vue.js移动端app实战1:初始配置详解
Jul 24 Javascript
Vue组件和Route的生命周期实例详解
Feb 10 Javascript
javascript将扁平的数据转为树形结构的高效率算法
Feb 27 Javascript
详解Node.JS模块 process
Aug 31 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
1982年日本摄影师镜头下的中国孩子 那无忧无虑的童年
2020/03/12 杂记
PHP中基本HTTP认证技巧分析
2015/03/16 PHP
ThinkPHP实现生成和校验验证码功能
2017/04/28 PHP
Laravel使用支付宝进行支付的示例代码
2017/08/16 PHP
PHP面向对象程序设计(OOP)之方法重写(override)操作示例
2018/12/21 PHP
php中访问修饰符的知识点总结
2019/01/27 PHP
PHP实现数组根据某个字段进行水平合并,横向合并案例分析
2019/10/08 PHP
Jquery下attr和removeAttr的使用方法
2010/12/28 Javascript
js中将HTMLCollection/NodeList/伪数组转换成数组的代码
2011/07/31 Javascript
jQuery的text()方法用法分析
2014/12/20 Javascript
JavaScript 实现打印,打印预览,打印设置
2014/12/30 Javascript
jQuery实现仿淘宝带有指示条的图片转动切换效果完整实例
2015/03/04 Javascript
javascript实现的简单计时器
2015/07/19 Javascript
非常实用的js验证框架实现源码 附原理方法
2016/06/08 Javascript
原生js封装添加class,删除class的实例
2017/11/06 Javascript
javaScript和jQuery自动加载简单代码实现方法
2017/11/24 jQuery
浅谈VueJS SSR 后端绘制内存泄漏的相关解决经验
2018/12/20 Javascript
深入理解 JS 垃圾回收
2019/06/03 Javascript
使用Vue CLI创建typescript项目的方法
2019/08/09 Javascript
JavaScript多种滤镜算法实现代码实例
2019/12/10 Javascript
Python 的 with 语句详解
2014/06/13 Python
Python实现单词拼写检查
2015/04/25 Python
解析Python中的生成器及其与迭代器的差异
2016/06/20 Python
python简单实现获取当前时间
2016/08/27 Python
解决Python中字符串和数字拼接报错的方法
2016/10/23 Python
Python 字典与字符串的互转实例
2017/01/13 Python
离线安装Pyecharts的步骤以及依赖包流程
2020/04/23 Python
Django2 连接MySQL及model测试实例分析
2019/12/10 Python
python分布式计算dispy的使用详解
2019/12/22 Python
基于python实现模拟数据结构模型
2020/06/12 Python
matplotlib基础绘图命令之errorbar的使用
2020/08/13 Python
python 操作excel表格的方法
2020/12/05 Python
详解如何使用CSS3中的结构伪类选择器和伪元素选择器
2020/01/06 HTML / CSS
瑞典时尚服装购物网站:Miinto.se
2017/10/30 全球购物
工程师求职简历的自我评价分享
2013/10/10 职场文书
驻村工作简报
2015/07/20 职场文书