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を文字列として受け入れ、ストリーム形式の画像を含む変更された文字列を返すメソッドを作成しました。varbinary[送信]ボタンをクリックすると、次のコードが実行され、サーバーのデータ型に保存できるHTMLページ全体が表示されます。

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

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>
于 2020-01-17T15:35:29.987 に答える