2

我在我的 aspx 页面中放置了一个 radeditor 控件,并将一些内容从 microsoft word 复制到其中,其中包含图像和一些文本数据。然后我保存了数据。我标记它正在将图像转换为流。我注意到图像的字符串是这样的:

<img alt="" src="" /><br />

我复制了这个源并将其粘贴到另一个 html 文件中并在浏览器中运行它,它显示了我复制的图像。

现在,我从其他网站(浏览器)复制了一些其他文本和图像并将其粘贴到编辑器,它显示图像标签和路径。

我想要的是从浏览器复制并粘贴图像到编辑器应该像上面那样转换它,而不是它具有 src="domain/path/filename.extesion"。

可能吗?另一种解决方案是从 content() 方法中获取所有图像标签并替换其 src 属性值。但为此,我必须从 URL 获取图像,将其转换为字节或流(我不知道你们是怎么做的),使用 base 64 进行编码,然后用实际源替换它。

有人可以帮忙吗??

谢谢...

4

3 回答 3

4

我自己解决了:

为此,我HTMLAgilityPack.dll在 bin 文件夹中添加并在项目中添加了它的引用。在页面中添加了一个telerik RadEditor控件。然后创建了一个方法,该方法parseHtmlToImageSource(string html)接受 html 作为字符串并以流格式返回带有图像的修改后的字符串。单击提交按钮后,将执行以下代码,并为您提供整个 HTML 页面的内容,您可以将其存储到服务器varbinary数据类型中。

protected void submitBtn_Click(object sender, EventArgs e)
{
            try
            {
                string html = parseHtmlToImageSource(editor.Content);
                byte[] array = new GetBytes(html);
        }
            catch (Exception ex)
            {
                throw ex
            }
}

private string parseHtmlToImageSource(string html)
{
            try
            {
                string modifiedHTML = html;
                HtmlDocument doc = new HtmlDocument();
                doc.LoadHtml(html);

                var srcTags = doc.DocumentNode.SelectNodes("//img");
                if (srcTags != null)
                {
                    foreach (var item in doc.DocumentNode.SelectNodes("//img[@src]"))//select only those img that have a src attribute..ahh not required to do [@src] i guess
                    {
                        string value = item.Attributes["src"].Value.ToString();

                        if (!(value.Contains("data:image/") && value.IndexOf("base64") > 0))
                        {
                            string extension = Path.GetExtension(item.Attributes["src"].Value.ToString().ToLower());

                            if (extension.Contains("."))
                            {
                                extension = extension.Remove(extension.IndexOf("."), extension.IndexOf(".") + 1);
                            }

                            item.Attributes["src"].Value = makeImageSrcData(item.Attributes["src"].Value.ToString(), extension);

                            modifiedHTML = modifiedHTML.Replace(value, item.Attributes["src"].Value.ToString());
                        }
                    }
                }

                //doc.ToString();

                //doc.Save("yourFile");//dont forget to save

                return modifiedHTML;
            }
            catch (Exception ex)
            {
                throw ex;
            }
}


private string makeImageSrcData(string url, string extension)
{
            try
            {
                WebResponse result = null;
                WebRequest request = WebRequest.Create(url);

                // Get the content
                result = request.GetResponse();

                Stream rStream = result.GetResponseStream();
                byte[] rBytes = ReadFully(rStream);

                return "data:image/" + extension + ";base64," + Convert.ToBase64String(rBytes, Base64FormattingOptions.None);
            }
            catch (Exception ex)
            {
                throw ex;
            }
}

public static byte[] GetBytes(string str)
{
    try
        {
            byte[] bytes = new byte[str.Length * sizeof(char)];
            System.Buffer.BlockCopy(str.ToCharArray(), 0, bytes, 0, bytes.Length);
            return bytes;
    }
        catch (Exception ex)
        {
                throw ex;
        }
}

public static byte[] ReadFully(Stream input)
{
            try
            {
                byte[] buffer = new byte[16 * 1024];
                using (MemoryStream ms = new MemoryStream())
                {
                    int read;
                    while ((read = input.Read(buffer, 0, buffer.Length)) > 0)
                    {
                        ms.Write(buffer, 0, read);
                    }
                    return ms.ToArray();
                }
            }
            catch (Exception ex)
            {
                throw ex;
            }
}

您还可以在读取数据或将其放置到编辑器时使用以下方法将字节转换为字符串:

例如 :

protected void getData()
{
    try
        {   // Make a code to get the data from data base here and then for varbinary fild I have used "fieldName"
        string contents = (byte[])ds.Tables[0].Rows[0]["fieldName"];
        editor.Content = new GetString(excelContents);
    }
    catch (Exception ex)
        {
                throw ex;
        }
}

public static string GetString(byte[] bytes)
{
    try
        {
            char[] chars = new char[bytes.Length / sizeof(char)];
            System.Buffer.BlockCopy(bytes, 0, chars, 0, bytes.Length);
            return new string(chars);
    }
    catch (Exception ex)
        {
                throw ex;
        }
}
于 2012-11-17T07:21:36.467 回答
0

我认为这提出了同样的问题:http ://www.telerik.com/community/forums/aspnet-ajax/editor/conver-image-to-stream-how.aspx

于 2012-11-06T14:15:17.740 回答
0

开发人员的回答解决了我的问题,但作为一个临时(快速和简单)的解决方案,您可以使用 OnClientPasteHtml 来防止粘贴 base64 编码图像:

<telerik:RadEditor ID="RadEditor1" runat="server" OnClientPasteHtml="OnClientPasteHtml">
</telerik:RadEditor> 
    <script type="text/javascript">
        function OnClientPasteHtml(sender, args) {
            if (args.get_value().indexOf(";base64,") > -1) {
                args.set_cancel(true);
            }
        }
    </script>
于 2020-01-17T15:35:29.987 回答