引用1.0.3版本或以上的Wesky.Net.OpenTools 包
1.0.3 版本提供图片转Base64字符串方案,并提供根据后缀名自动识别Mime类型,合成标准URI
开源项目地址:
Gitee:https://gitee.com/dreamer_j/open-tools.git
Github:https://github.com/LittleLittleRobot/OpenTools.git
为了简单操作,我直接把base64字符串,外面套一层,让它支持md文件展示。图片地址为桌面上个人公众号图片地址,格式类型为jpg
1 var file = @"XXX.jpg";
2 var data = Wesky.Net.OpenTools.Converter.ImageConvert.ConvertImageToBase64(file);
3 var mdString = $"![avatar]({data})";
4 Console.WriteLine(mdString);
运行程序,得到base64字符串.base64字符串。base64字符串,使用格式:![avatar](base64字符串)的形式,即可被markdown所识别,并显示未原始图片。
复制该全部字符串内容,粘贴到任意markdown文本编辑器内。以下我用Typora实验,可以看到自动解析出文本,并显示了我用来实验的图片。
核心代码解析:
1 /// <summary>
2 /// 将图片文件转换为 Base64 编码的字符串。
3 /// Converts an image file to a Base64-encoded string.
4 /// </summary>
5 /// <param name="imagePath">图片文件的路径。Path to the image file.</param>
6 /// <returns>返回 Base64 编码的图片字符串。Returns a Base64-encoded image string.</returns>
7 public static string ConvertImageToBase64(string imagePath)
8 {
9 if (!File.Exists(imagePath))
10 {
11 throw new FileNotFoundException("指定的图片路径不存在。Specified image path does not exist.");
12 }
13 byte[] imageBytes = File.ReadAllBytes(imagePath);
14 string mimeType = GetMimeType(imagePath);
15 string base64String = Convert.ToBase64String(imageBytes);
16 return $"data:{mimeType};base64,{base64String}";
17 }
支持的图片格式为:
case ".bmp":
return "image/bmp";
case ".gif":
return "image/gif";
case ".jpg":
case ".jpeg":
return "image/jpeg";
case ".png":
return "image/png";
case ".tif":
case ".tiff":
return "image/tiff";
case ".ico":
return "image/x-icon";