zoukankan      html  css  js  c++  java
  • C# Base64编码和图片的互相转换代码

    Base64编码在Web方面有很多应用,譬如在URL、电子邮件方面。网上有很多相关的资源用于提供Base64编码和其他编码的转换,.Net Framework也提供了现成的功能类(System.Convert)用于将二进制数据转换为Base64字符串

    转换流程

          我们已经做了一个编辑器,这个编辑器可以以xml格式存储一些信息。在存储图片信息时我们碰到了一些问题。我们本来在xml信息中存储的是图片的路径,然而一旦客户把这个信息copy到其他电脑上而没有同时copy相关的图片时,就会出现一些问题。后来,我们把图片数据转换为Base64编码,替代了原先存储图片路径的方式。

    转换流程

          将图片转化为Base64字符串的流程是:首先使用BinaryFormatter将图片文件序列化为二进制数据,然后使用Convert类的ToBase64String方法。将Base64字符串转换为图片的流程正好相反:使用Convert类的FromBase64String得到图片文件的二进制数据,然后使用BinaryFormatter反序列化方法。

    /// <summary>
        /// 将图片数据转换为Base64字符串
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void ToBase64(object sender, EventArgs e)
        {
          Image img = this.pictureBox.Image;
          BinaryFormatter binFormatter = new BinaryFormatter();
          MemoryStream memStream = new MemoryStream();
          binFormatter.Serialize(memStream, img);
          byte[] bytes = memStream.GetBuffer();
          string base64 = Convert.ToBase64String(bytes);
          this.richTextBox.Text = base64;
        }
     
        /// <summary>
        /// 将Base64字符串转换为图片
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void ToImage(object sender, EventArgs e)
        {
          string base64 = this.richTextBox.Text;
          byte[] bytes = Convert.FromBase64String(base64);
          MemoryStream memStream = new MemoryStream(bytes);
          BinaryFormatter binFormatter = new BinaryFormatter();
          Image img = (Image)binFormatter.Deserialize(memStream);
          this.pictureBox.Image = img;
        }
  • 相关阅读:
    C# 获取文件名及扩展名
    Javscript调用iframe框架页面中函数的方法
    jquery事件重复绑定的几种解决方法 (二)
    Jquery 点击事件重复获取叠加 (一)
    .NET 即时通信,WebSocket服务端实例
    .Net ASP.NET 打开指定文件夹
    动态 hover 使用变相使用
    给 layui upload 带每个文件的进度条, .net 后台代码
    layui upload 后台获取不到值
    ECharts配置项之title(标题)
  • 原文地址:https://www.cnblogs.com/rinack/p/4260213.html
Copyright © 2011-2022 走看看