我在我的aspx页面中放置了一个radeditor控件,并将一些内容从microsoft word粘贴到包含图像和一些文本数据的内容中。然后我保存了数据。我标记它正在将图像转换为流。我注意到图像的字符串是这样的:
<img alt="" src="" /><br />
我复制了这个源并将其粘贴到另一个html文件中并在浏览器中运行,它显示了我复制的图像。
现在,我已经将一些其他文本与来自其他网站(浏览器)的图像一起复制并粘贴到编辑器中,它正在显示图像标记以及路径。
我想要的是将图像从浏览器复制并粘贴到编辑器应该像上面那样将其转换为src =“domain / path / filename.extesion”。
有可能吗?另一种解决方案是从content()方法获取所有图像标记并替换其src属性值。但为此,我必须从URL获取图像,将其转换为字节或流(我不知道你们是怎么做的),使用base 64进行编码,然后用实际源替换它。
任何人都可以帮忙吗?
谢谢...
答案 0 :(得分:4)
解决了我自己:
为此我在bin文件夹中添加了HTMLAgilityPack.dll
并在项目中添加了它的引用。在页面中添加了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;
}
}
答案 1 :(得分:0)
我认为这会问同样的问题:http://www.telerik.com/community/forums/aspnet-ajax/editor/conver-image-to-stream-how.aspx
答案 2 :(得分:0)
Dev的答案解决了我的问题,但作为一个临时(快速,简单)的解决方案,您可以使用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>