Change HTML with CSS inline to use data Url












1















In want to, on the fly, change an HTML similar to this:



<html><head><style>
body {
background: transparent url(http://example.com/image.gif) no-repeat right bottom;
}
</style><head>
<body>
<img src="http://example.com/image2.gif"/>
</body>
</html>


To (urls are cut):



<html><head><style>
body {
background: transparent url(...) no-repeat right bottom;
}
</style>
<head>
<body>
<img src="...."/>
</body>
</html>


Now I use this code:



private string EmbebedImages(string strHtml)
{
var doc = new HtmlAgilityPack.HtmlDocument();
doc.LoadHtml(strHtml);

foreach (var imgNode in doc.DocumentNode.SelectNodes("//img[@src]"))
{
string url = imgNode.Attributes["src"].Value;
if (url.StartsWith("http"))
{
using (var webClient = new WebClient())
{
var imageAsByteArray = webClient.DownloadData(url);
string mimeType = MimeMapping.GetMimeMapping(url);

imgNode.Attributes["src"].Value = "data:" + mimeType + ";base64," +
Convert.ToBase64String(imageAsByteArray);
}
}
}

return doc.DocumentNode.OuterHtml;
}


But my code ignores urls in CSS.



Is it possible to make this change simple? I tried with some css-libraries, but I can't find a simple form...










share|improve this question

























  • you are just accessingimg with your c# code. You mean you need css background image with HtmlAgilityPack?

    – Znaneswar
    Nov 15 '18 at 9:38













  • I need change all urls in style. Now I only change urls in IMG tag. This is only a sample.

    – Victor Sanchez
    Nov 15 '18 at 10:03
















1















In want to, on the fly, change an HTML similar to this:



<html><head><style>
body {
background: transparent url(http://example.com/image.gif) no-repeat right bottom;
}
</style><head>
<body>
<img src="http://example.com/image2.gif"/>
</body>
</html>


To (urls are cut):



<html><head><style>
body {
background: transparent url(...) no-repeat right bottom;
}
</style>
<head>
<body>
<img src="...."/>
</body>
</html>


Now I use this code:



private string EmbebedImages(string strHtml)
{
var doc = new HtmlAgilityPack.HtmlDocument();
doc.LoadHtml(strHtml);

foreach (var imgNode in doc.DocumentNode.SelectNodes("//img[@src]"))
{
string url = imgNode.Attributes["src"].Value;
if (url.StartsWith("http"))
{
using (var webClient = new WebClient())
{
var imageAsByteArray = webClient.DownloadData(url);
string mimeType = MimeMapping.GetMimeMapping(url);

imgNode.Attributes["src"].Value = "data:" + mimeType + ";base64," +
Convert.ToBase64String(imageAsByteArray);
}
}
}

return doc.DocumentNode.OuterHtml;
}


But my code ignores urls in CSS.



Is it possible to make this change simple? I tried with some css-libraries, but I can't find a simple form...










share|improve this question

























  • you are just accessingimg with your c# code. You mean you need css background image with HtmlAgilityPack?

    – Znaneswar
    Nov 15 '18 at 9:38













  • I need change all urls in style. Now I only change urls in IMG tag. This is only a sample.

    – Victor Sanchez
    Nov 15 '18 at 10:03














1












1








1








In want to, on the fly, change an HTML similar to this:



<html><head><style>
body {
background: transparent url(http://example.com/image.gif) no-repeat right bottom;
}
</style><head>
<body>
<img src="http://example.com/image2.gif"/>
</body>
</html>


To (urls are cut):



<html><head><style>
body {
background: transparent url(...) no-repeat right bottom;
}
</style>
<head>
<body>
<img src="...."/>
</body>
</html>


Now I use this code:



private string EmbebedImages(string strHtml)
{
var doc = new HtmlAgilityPack.HtmlDocument();
doc.LoadHtml(strHtml);

foreach (var imgNode in doc.DocumentNode.SelectNodes("//img[@src]"))
{
string url = imgNode.Attributes["src"].Value;
if (url.StartsWith("http"))
{
using (var webClient = new WebClient())
{
var imageAsByteArray = webClient.DownloadData(url);
string mimeType = MimeMapping.GetMimeMapping(url);

imgNode.Attributes["src"].Value = "data:" + mimeType + ";base64," +
Convert.ToBase64String(imageAsByteArray);
}
}
}

return doc.DocumentNode.OuterHtml;
}


But my code ignores urls in CSS.



Is it possible to make this change simple? I tried with some css-libraries, but I can't find a simple form...










share|improve this question
















In want to, on the fly, change an HTML similar to this:



<html><head><style>
body {
background: transparent url(http://example.com/image.gif) no-repeat right bottom;
}
</style><head>
<body>
<img src="http://example.com/image2.gif"/>
</body>
</html>


To (urls are cut):



<html><head><style>
body {
background: transparent url(...) no-repeat right bottom;
}
</style>
<head>
<body>
<img src="...."/>
</body>
</html>


Now I use this code:



private string EmbebedImages(string strHtml)
{
var doc = new HtmlAgilityPack.HtmlDocument();
doc.LoadHtml(strHtml);

foreach (var imgNode in doc.DocumentNode.SelectNodes("//img[@src]"))
{
string url = imgNode.Attributes["src"].Value;
if (url.StartsWith("http"))
{
using (var webClient = new WebClient())
{
var imageAsByteArray = webClient.DownloadData(url);
string mimeType = MimeMapping.GetMimeMapping(url);

imgNode.Attributes["src"].Value = "data:" + mimeType + ";base64," +
Convert.ToBase64String(imageAsByteArray);
}
}
}

return doc.DocumentNode.OuterHtml;
}


But my code ignores urls in CSS.



Is it possible to make this change simple? I tried with some css-libraries, but I can't find a simple form...







c# html css html-agility-pack






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 15 '18 at 9:16







Victor Sanchez

















asked Nov 15 '18 at 8:32









Victor SanchezVictor Sanchez

318423




318423













  • you are just accessingimg with your c# code. You mean you need css background image with HtmlAgilityPack?

    – Znaneswar
    Nov 15 '18 at 9:38













  • I need change all urls in style. Now I only change urls in IMG tag. This is only a sample.

    – Victor Sanchez
    Nov 15 '18 at 10:03



















  • you are just accessingimg with your c# code. You mean you need css background image with HtmlAgilityPack?

    – Znaneswar
    Nov 15 '18 at 9:38













  • I need change all urls in style. Now I only change urls in IMG tag. This is only a sample.

    – Victor Sanchez
    Nov 15 '18 at 10:03

















you are just accessingimg with your c# code. You mean you need css background image with HtmlAgilityPack?

– Znaneswar
Nov 15 '18 at 9:38







you are just accessingimg with your c# code. You mean you need css background image with HtmlAgilityPack?

– Znaneswar
Nov 15 '18 at 9:38















I need change all urls in style. Now I only change urls in IMG tag. This is only a sample.

– Victor Sanchez
Nov 15 '18 at 10:03





I need change all urls in style. Now I only change urls in IMG tag. This is only a sample.

– Victor Sanchez
Nov 15 '18 at 10:03












1 Answer
1






active

oldest

votes


















1














you can't do that with HtmlAgilityPack but Try Regex



using System.Text.RegularExpressions;

private string EmbebedImages(string strHtml) {
var htmlString = .......load html string....;
string currentURL;

var images_url = Regex.Matches(htmlString, @"(?:https?://.*?.(gif|png|jpg|jpeg))");
foreach(var url in images_url) {
currentURL = url.ToString();
using(var webClient = new WebClient()) {
var imageAsByteArray = webClient.DownloadData(currentURL);
string mimeType = MimeMapping.GetMimeMapping(currentURL);
string dataURL = "data:" + mimeType + ";base64," + Convert.ToBase64String(imageAsByteArray);
htmlString = htmlString.Replace(currentURL, dataURL);
}
}

return htmlString;
}





share|improve this answer























    Your Answer






    StackExchange.ifUsing("editor", function () {
    StackExchange.using("externalEditor", function () {
    StackExchange.using("snippets", function () {
    StackExchange.snippets.init();
    });
    });
    }, "code-snippets");

    StackExchange.ready(function() {
    var channelOptions = {
    tags: "".split(" "),
    id: "1"
    };
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function() {
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled) {
    StackExchange.using("snippets", function() {
    createEditor();
    });
    }
    else {
    createEditor();
    }
    });

    function createEditor() {
    StackExchange.prepareEditor({
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader: {
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    },
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    });


    }
    });














    draft saved

    draft discarded


















    StackExchange.ready(
    function () {
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53315231%2fchange-html-with-css-inline-to-use-data-url%23new-answer', 'question_page');
    }
    );

    Post as a guest















    Required, but never shown

























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    1














    you can't do that with HtmlAgilityPack but Try Regex



    using System.Text.RegularExpressions;

    private string EmbebedImages(string strHtml) {
    var htmlString = .......load html string....;
    string currentURL;

    var images_url = Regex.Matches(htmlString, @"(?:https?://.*?.(gif|png|jpg|jpeg))");
    foreach(var url in images_url) {
    currentURL = url.ToString();
    using(var webClient = new WebClient()) {
    var imageAsByteArray = webClient.DownloadData(currentURL);
    string mimeType = MimeMapping.GetMimeMapping(currentURL);
    string dataURL = "data:" + mimeType + ";base64," + Convert.ToBase64String(imageAsByteArray);
    htmlString = htmlString.Replace(currentURL, dataURL);
    }
    }

    return htmlString;
    }





    share|improve this answer




























      1














      you can't do that with HtmlAgilityPack but Try Regex



      using System.Text.RegularExpressions;

      private string EmbebedImages(string strHtml) {
      var htmlString = .......load html string....;
      string currentURL;

      var images_url = Regex.Matches(htmlString, @"(?:https?://.*?.(gif|png|jpg|jpeg))");
      foreach(var url in images_url) {
      currentURL = url.ToString();
      using(var webClient = new WebClient()) {
      var imageAsByteArray = webClient.DownloadData(currentURL);
      string mimeType = MimeMapping.GetMimeMapping(currentURL);
      string dataURL = "data:" + mimeType + ";base64," + Convert.ToBase64String(imageAsByteArray);
      htmlString = htmlString.Replace(currentURL, dataURL);
      }
      }

      return htmlString;
      }





      share|improve this answer


























        1












        1








        1







        you can't do that with HtmlAgilityPack but Try Regex



        using System.Text.RegularExpressions;

        private string EmbebedImages(string strHtml) {
        var htmlString = .......load html string....;
        string currentURL;

        var images_url = Regex.Matches(htmlString, @"(?:https?://.*?.(gif|png|jpg|jpeg))");
        foreach(var url in images_url) {
        currentURL = url.ToString();
        using(var webClient = new WebClient()) {
        var imageAsByteArray = webClient.DownloadData(currentURL);
        string mimeType = MimeMapping.GetMimeMapping(currentURL);
        string dataURL = "data:" + mimeType + ";base64," + Convert.ToBase64String(imageAsByteArray);
        htmlString = htmlString.Replace(currentURL, dataURL);
        }
        }

        return htmlString;
        }





        share|improve this answer













        you can't do that with HtmlAgilityPack but Try Regex



        using System.Text.RegularExpressions;

        private string EmbebedImages(string strHtml) {
        var htmlString = .......load html string....;
        string currentURL;

        var images_url = Regex.Matches(htmlString, @"(?:https?://.*?.(gif|png|jpg|jpeg))");
        foreach(var url in images_url) {
        currentURL = url.ToString();
        using(var webClient = new WebClient()) {
        var imageAsByteArray = webClient.DownloadData(currentURL);
        string mimeType = MimeMapping.GetMimeMapping(currentURL);
        string dataURL = "data:" + mimeType + ";base64," + Convert.ToBase64String(imageAsByteArray);
        htmlString = htmlString.Replace(currentURL, dataURL);
        }
        }

        return htmlString;
        }






        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Nov 19 '18 at 12:02









        ewwinkewwink

        12k22339




        12k22339
































            draft saved

            draft discarded




















































            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid



            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.


            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53315231%2fchange-html-with-css-inline-to-use-data-url%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            Bressuire

            Vorschmack

            Quarantine