使用Visual Studio 2010写Data Url生成工具C#版本

声明:本文系本人按照真实经历原创。未经许可,谢绝转载。

此文百度经验版本号:怎样用Visual Studio 2010打造Data Url生成工具

源代码下载:用Visual Studio 2010编写Data Url生成工具C#源代码

相关文章:Data Url生成工具之HTML5 FileReader实现

什么是Data Url呢?Data URI scheme是在RFC2397中定义的,目的是将一些小的数据。直接嵌入到网页中,从而不用再从外部文件加载。

比如:

<img src="" width="16" height="16" />

img标签的src属性值就是Data Url。

在上面的Data URI中。data表示取得数据的协定名称,image/png 是数据类型名称,base64 是数据的编码方法,逗号后面就是这个image/png文件base64编码后的数据。

眼下,Data URI scheme支持的类型有:
data:,文本数据
data:text/plain,文本数据
data:text/html,HTML代码
data:text/html;base64,base64编码的HTML代码
data:text/css,CSS代码
data:text/css;base64,base64编码的CSS代码
data:text/javascript,Javascript代码
data:text/javascript;base64,base64编码的Javascript代码
编码的gif图片数据
编码的png图片数据
编码的jpeg图片数据
编码的icon图片数据

那么怎样才干生成Data Url呢?今天我就教大家自己用Visual Studio 2010打造一款Data Url生成工具的方法。

打开Visual Studio 2010

使用Visual Studio 2010写Data Url生成工具C#版本

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdGVzdGNzX2Ru/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="" />

新建项目:文件》新建》项目

使用Visual Studio 2010写Data Url生成工具C#版本

选择c#》Windows窗口应用程序》输入项目名称

使用Visual Studio 2010写Data Url生成工具C#版本

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdGVzdGNzX2Ru/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="" />

拖动窗口到合适的大小

使用Visual Studio 2010写Data Url生成工具C#版本

改动窗口的标题为:Data Url 生成工具

使用Visual Studio 2010写Data Url生成工具C#版本

分别加入一个Label。两个TextBox,一个Button组件

使用Visual Studio 2010写Data Url生成工具C#版本

改动组件的“Name”属性,以及Text属性

使用Visual Studio 2010写Data Url生成工具C#版本

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdGVzdGNzX2Ru/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="" />使用Visual Studio 2010写Data Url生成工具C#版本

双击浏览按钮加入关键代码

        private void button_browse_Click(object sender, EventArgs e)
{
OpenFileDialog fbd = new OpenFileDialog();
fbd.Title = "请选择一张图片:";
fbd.CheckFileExists = true;
fbd.FileName = Environment.GetFolderPath(Environment.SpecialFolder.MyComputer);
if (fbd.ShowDialog() == System.Windows.Forms.DialogResult.OK)
{
textBox_saveDir.Text = fbd.FileName;
try
{
Image img = Image.FromFile(textBox_saveDir.Text, true);
System.IO.MemoryStream ms = new System.IO.MemoryStream();
System.Drawing.Imaging.ImageFormat fmt = System.Drawing.Imaging.ImageFormat.Png;
string ext = Path.GetExtension(textBox_saveDir.Text);
switch (ext)
{
case "gif":
fmt = System.Drawing.Imaging.ImageFormat.Gif;
break;
default:
ext = "png";
break;
}
img.Save(ms, fmt);
textBox1.Text = "<img src=\"data:image/" + ext + ";base64," + Convert.ToBase64String(ms.GetBuffer())
+ "\" width=\"" + img.Width +"\" height=\"" + img.Height +"\" />";
}
catch (Exception ex)
{
textBox1.Text = "错误:" + ex.Message + "\r\n堆栈:" + ex.StackTrace;
}
}
}

生成解决方式。启动调试

使用Visual Studio 2010写Data Url生成工具C#版本

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdGVzdGNzX2Ru/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="" />

选择一张图片

使用Visual Studio 2010写Data Url生成工具C#版本

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdGVzdGNzX2Ru/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="" />

点击打开后,就会马上生成Data Url了,这里直接把Data Url放到img标签里了,方便測试

使用Visual Studio 2010写Data Url生成工具C#版本

怎么測试呢?

新建一个文本文档,把整个img标签的内容复制粘贴到文档中,保存;

然后将文件的扩展名改为“.html”;

然后在文件上单击鼠标右键》打开方式》选择一个浏览器,就能够看到效果了。

使用Visual Studio 2010写Data Url生成工具C#版本

使用Visual Studio 2010写Data Url生成工具C#版本

你学会了吗?

补充 2015.04.25
不知道有没有同学下载使用或调试,在尝试将尺寸比較大的图上生成DataURL时。
抛出了下面异常:

版权声明:本文博客原创文章,博客,未经同意,不得转载。

上一篇:【Data URL】【RE】【bugku】逆向入门writeup


下一篇:PHP & “Data” URL scheme(转)