webClient.DownloadData 扔 'System.IO.PathTooLongException'

webClient.DownloadData throw 'System.IO.PathTooLongException'

我有一个方法是通过URL下载图片,有时URL变成这样,其中包含很长的路径(我删除了一些字符串,它只是没有成为长问题:):



然后当我调试或下载图像时,我得到这个异常:

var DL = webClient.DownloadData(base64)
The specified path and / or file name is too long. The fully qualified name must be less than 260 characters and the folder name must be less than 248 characters.

我也研究了建议在 webconfig 中添加 <httpRuntime maxUrlLength="260" /> 或使用不同的库,但不幸的是它没有帮助解决问题。
任何人都可以帮助我或指出正确的方向:)
提前致谢。

控制器:

[HttpPost]
public string DownloadImagesFromLinkViaURL(ImagesViewModel model)
{
 var RandomName = Guid.NewGuid().ToString("N").Substring(0,12);
    using (WebClient webClient = new WebClient())
    {
        try
        {
            string base64 = model.ImageURL.Substring(model.ImageURL.IndexOf(',') + 1);
            byte[] data = Convert.FromBase64String(base64);
            var DL = webClient.DownloadData(base64);

            using (MemoryStream mem = new MemoryStream(DL))
            {
                using (var content = Image.FromStream(mem))
                {
                    var format = ImageFormat.Png.ToString().ToLower();

                    var PathIMG = "https://SomeName.com/folder/" + RandomName + "." + format;

                    content.Save(Path.Combine(Server.MapPath(PathIMG)));
                    ImageStore img = new ImageStore();

                    img.ProducentVarenr = model.ImageName;
                    img.ImageOrginalURL = model.ImageURL;
                    img.ImageRandomName = RandomName;
                    img.LinktilBillede = PathIMG;
                    db.ImageStoreList.Add(img);
                    db.SaveChanges();
                }
            }

        }
        catch (ArgumentException)
        {
            return "content is not image";
        }

    }
    return "saved";
}

视图模态:

public class ImagesViewModel
{
    public int ImageID { get; set; }
    public string ImageURL { get; set; }
    public string ImageName { get; set; }
    public string ImagePath { get; set; }
    public string RandomName { get; set; }
}

您看到的数据不是 url 或路径。它是显示为 Base64 字符串的图像数据。因为您已经有图像数据,所以不需要任何下载。

如果您粘贴 非常长的字符串 this base64 到图像转换器工具,您会看到实际图像。

使用给定的 base64 字符串,您可以将其保存到具有以下样式的文件中:

File.WriteAllBytes(@"c:\yourfile", Convert.FromBase64String(base64));

这是(未测试和未重构的)原始方法的固定版本,如回答评论中所要求。

[HttpPost]
public string DownloadImagesFromLinkViaURL(ImagesViewModel model)
{
    var RandomName = Guid.NewGuid().ToString("N").Substring(0, 12);
    var format = ImageFormat.Png.ToString().ToLower();

    var PathIMG = "https://SomeName.com/folder/" + RandomName + "." + format;
    if (model.ImageURL.StartsWith("data:image"))
    {
        string base64 = model.ImageURL.Substring(model.ImageURL.IndexOf(',') + 1);
        File.WriteAllBytes($@"c:\temp\{RandomName}.jpeg", Convert.FromBase64String(base64));
        ImageStore img = new ImageStore();

        img.ProducentVarenr = model.ImageName;
        img.ImageOrginalURL = model.ImageURL;
        img.ImageRandomName = RandomName;
        img.LinktilBillede = PathIMG;
        db.ImageStoreList.Add(img);
        db.SaveChanges();
        return "saved";
    }
    using (WebClient webClient = new WebClient())
    {
        try
        {
            byte[] data = Convert.FromBase64String(base64);
            var DL = webClient.DownloadData(base64);

            using (MemoryStream mem = new MemoryStream(DL))
            {
                using (var content = Image.FromStream(mem))
                {
                    content.Save(Path.Combine(Server.MapPath(PathIMG)));
                    ImageStore img = new ImageStore();

                    img.ProducentVarenr = model.ImageName;
                    img.ImageOrginalURL = model.ImageURL;
                    img.ImageRandomName = RandomName;
                    img.LinktilBillede = PathIMG;
                    db.ImageStoreList.Add(img);
                    db.SaveChanges();
                }
            }

        }
        catch (ArgumentException)
        {
            return "content is not image";
        }

    }
    return "saved";
}