base64编码在silverlight中的使用

简介: 在传统的.net应用中,使用base64编码字符串是一件很轻松的事情,比如下面这段代码演示了如何将本地文件转化为base64字符串,并且将base64字符串又还原为图片文件.base64编码在传统.net程序中的应用(by 菩提树下的杨过 http://yjmyzz.
在传统的.net应用中,使用base64编码字符串是一件很轻松的事情,比如下面这段代码演示了如何将本地文件转化为base64字符串,并且将base64字符串又还原为图片文件.
img_405b18b4b6584ae338e0f6ecaf736533.gif base64编码在传统.net程序中的应用(by 菩提树下的杨过 http://yjmyzz.cnblogs.com/)
using  System;
using  System.Drawing;
using  System.Drawing.Imaging;
using  System.IO;


namespace  Base64Study
{
    
///   <summary>
    
///  base64编码在传统.net程序中的应用(by 菩提树下的杨过  http://yjmyzz.cnblogs.com/ )
    
///   </summary>
     class  Program
    {
        
static   void  Main( string [] args)
        {           

            
string  imgstring  =  GetBase64FromFile( " c:\\self.png " );
            Console.WriteLine(imgstring);

            Bitmap bitmap 
=  GetImageFromBase64(imgstring);
            bitmap.Save(
" c:\\self2.png " , ImageFormat.Png);

            Console.Read();
        
           
        }

        
///   <summary>
        
///  将文件转换为base64字符串
        
///   </summary>
        
///   <param name="filePath"></param>
        
///   <returns></returns>
         static   string  GetBase64FromFile( string  filePath)         
        {
            
byte [] b  =  File.ReadAllBytes(filePath);
            
return  Convert.ToBase64String(b);
        }

        
///   <summary>
        
///  从base64字符串还原图片
        
///   </summary>
        
///   <param name="base64string"></param>
        
///   <returns></returns>
         static  Bitmap GetImageFromBase64( string  base64string) 
        {
            
byte [] b  =  Convert.FromBase64String(base64string);
            MemoryStream ms 
=   new  MemoryStream(b);
            Bitmap bitmap 
=   new  Bitmap(ms);
            
return  bitmap;
        }
    }
}

 

但是到了silverlight环境中,这种简单的操作方式却无法使用了,幸好网上有一个开源的免费组件FluxJpeg,同时国外有高人已经利用该组件写出了将位图转化为base64的方法,这里我们借用一下即可:

img_405b18b4b6584ae338e0f6ecaf736533.gif 代码
< UserControl  x:Class ="SLBase64.MainPage"
    xmlns
="http://schemas.microsoft.com/winfx/2006/xaml/presentation"  
    xmlns:x
="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:d
="http://schemas.microsoft.com/expression/blend/2008"  xmlns:mc ="http://schemas.openxmlformats.org/markup-compatibility/2006"  
    mc:Ignorable
="d"  d:DesignWidth ="640"  d:DesignHeight ="480" >
  
< StackPanel  x:Name ="LayoutRoot" >
        
< Image   x:Name ="img"  Height ="100"  Stretch ="Uniform"  Source ="img/self.png" ></ Image >
        
< Button  x:Name ="btnToBase64"  Content ="转为base64字符串"  Width ="200"  Margin ="0,3,0,0"   Click ="btnToBase64_Click" ></ Button >
        
< TextBox  Text =""  x:Name ="txtBase64"  TextWrapping ="Wrap"  Height ="150"  Margin ="0,3"  VerticalScrollBarVisibility ="Auto" ></ TextBox >
        
< Button  x:Name ="btnToImg"  Content ="将上述base64字符串还原为图片"  Width ="200"  Margin ="0,0,0,3"  Click ="btnToImg_Click" ></ Button >
        
< Image   x:Name ="img2"  Height ="100"  Stretch ="Uniform" ></ Image >
    
</ StackPanel >
</ UserControl >

 

 

img_405b18b4b6584ae338e0f6ecaf736533.gif 代码
using  System;
using  System.IO;
using  System.Windows;
using  System.Windows.Controls;
using  System.Windows.Media.Imaging;
using  FluxJpeg.Core;
using  FluxJpeg.Core.Encoder;

namespace  SLBase64
{
    
public   partial   class  MainPage : UserControl
    {
        
public  MainPage()
        {
            InitializeComponent();
        }

        
///   <summary>
        
///  老外写的方法:将WriteableBitmap转化为base64位字符串
        
///   </summary>
        
///   <param name="bitmap"></param>
        
///   <returns></returns>
         private   string  GetBase64Image(WriteableBitmap bitmap)
        {
            
int  width  =  bitmap.PixelWidth;
            
int  height  =  bitmap.PixelHeight;
            
int  bands  =   3 ;
            
byte [][,] raster  =   new   byte [bands][,];

            
for  ( int  i  =   0 ; i  <  bands; i ++ )
            {
                raster[i] 
=   new   byte [width, height];
            }

            
for  ( int  row  =   0 ; row  <  height; row ++ )
            {
                
for  ( int  column  =   0 ; column  <  width; column ++ )
                {
                    
int  pixel  =  bitmap.Pixels[width  *  row  +  column];
                    raster[
0 ][column, row]  =  ( byte )(pixel  >>   16 );
                    raster[
1 ][column, row]  =  ( byte )(pixel  >>   8 );
                    raster[
2 ][column, row]  =  ( byte )pixel;
                }
            }

            ColorModel model 
=   new  ColorModel { colorspace  =  ColorSpace.RGB };
            FluxJpeg.Core.Image img 
=   new  FluxJpeg.Core.Image(model, raster);
            MemoryStream stream 
=   new  MemoryStream();
            JpegEncoder encoder 
=   new  JpegEncoder(img,  100 , stream);
            encoder.Encode();

            stream.Seek(
0 , SeekOrigin.Begin);
            
byte [] binaryData  =   new  Byte[stream.Length];
            
long  bytesRead  =  stream.Read(binaryData,  0 , ( int )stream.Length);

            
string  base64String  =
                    System.Convert.ToBase64String(binaryData,
                                                  
0 ,
                                                  binaryData.Length);

            
return  base64String;

        }

        
private   void  btnToBase64_Click( object  sender, RoutedEventArgs e)
        {
            WriteableBitmap wb 
=   new  WriteableBitmap(img,  null );
            txtBase64.Text 
=   "" ;
            txtBase64.Text 
=  GetBase64Image(wb);
        }

        
private   void  btnToImg_Click( object  sender, RoutedEventArgs e)
        {
            
if  (txtBase64.Text  ==   "" ) {  return ; }
            
try
            {
                img2.Source 
=   null ;

                
byte [] b  =  Convert.FromBase64String(txtBase64.Text);
                MemoryStream ms 
=   new  MemoryStream(b);
                BitmapImage bitImage 
=   new  BitmapImage();
                bitImage.SetSource(ms);

                img2.Source 
=  bitImage;
            }
            
catch  (Exception ex) { MessageBox.Show(ex.Message.ToString()); }
        }
    }
}

 

最后是示例源码地址:http://files.cnblogs.com/yjmyzz/Base64Study.rar

转载请注明出处(菩提树下的杨过 http://www.cnblogs.com/yjmyzz/archive/2010/01/14/1647918.html)

目录
相关文章
|
8月前
|
数据采集 算法 安全
Base64 编码原理 && 实现
Base64 编码原理 && 实现
|
存储 数据库 索引
深入浅出理解base编码
深入浅出理解base编码
156 0
深入浅出理解base编码
|
存储 索引
Base64编码
通过阅读本篇文章,你可以了解到: 1、Base64 编码的作用 2、Base64 编码的规则 3、Base64 索引表
162 0
Base64编码
|
开发者
base64解码工具
base64解码工具
base64解码工具
|
前端开发 JavaScript
前端实现 base64 编码和解码
前端实现 base64 编码和解码
426 0
前端实现 base64 编码和解码
|
Java
小程序中base64解码/编码
很多人都在为小程序如何实现base64编码/解码困扰,于是我参考前端大佬们对JavaScript中实现base64的文章进行了改写。简单实现了一个。。希望能帮助到小程序开发一线的大家吧、 不多说直接上代码: /** * UTF16和UTF8转换对照表 * U+00000000 – U+000000...
4733 1
|
算法 Android开发
【密码学】Base64 编码 ( Base64 简介 | Base64 编码原理 | 最后编码组字节不足时补位 ‘=‘ 符号 | Base64 编码实现参考 )(二)
【密码学】Base64 编码 ( Base64 简介 | Base64 编码原理 | 最后编码组字节不足时补位 ‘=‘ 符号 | Base64 编码实现参考 )(二)
309 0
|
算法 区块链 索引
【密码学】Base64 编码 ( Base64 简介 | Base64 编码原理 | 最后编码组字节不足时补位 ‘=‘ 符号 | Base64 编码实现参考 )(一)
【密码学】Base64 编码 ( Base64 简介 | Base64 编码原理 | 最后编码组字节不足时补位 ‘=‘ 符号 | Base64 编码实现参考 )(一)
335 0
【密码学】Base64 编码 ( Base64 简介 | Base64 编码原理 | 最后编码组字节不足时补位 ‘=‘ 符号 | Base64 编码实现参考 )(一)
|
编解码 Go 区块链
Go语言实现Base64、Base58编码与解码
目录 1. 常见的编码 2. go语言实现base64的编码与解码 2.1 Base64编码原理 2.2 实现Base64的编码与解码 3. go语言实现base58编码与解码 3.1 base58的编码过程 3.2 base58编解码具体实现 4. 最后
336 0
Go语言实现Base64、Base58编码与解码
|
开发工具
新增2款开发工具:base64编码解码,unicode编码解码
最近由于工作需要,制定了一份底层通信协议,为了保证协议顺利传输任意内容,规定数据段必须采用base64编码,来规避其他字符对于协议解析的影响。然后就顺手为本站新增2款开发人员工具。 base64编码解码 体验地址:https://www.opengps.cn/Tools/Base64/Index.aspx unicode编码解码 体验地址:https://www.opengps.cn/Tools/Unicode/Index.aspx 原文地址: https://www.opengps.cn/Blog/View.aspx?id=382 文章的更新编辑依此链接为准。
1240 0