Writing Base64 Image in Params

Hi All

I have looked for a few hours but I am stuck on this one
One of the Parameters for my page is a logo that is a base64 string.

The rendered page does not display the image as the src seems incorrect. I have validated the image renders correctly with online tools.

Any help is appreciated.

The page is as follows
{
“json”: true,
“type”: “company”,
“draft”: false,
“title”: “b2”,
“logo”: “”,
“summary”: “A really cool company”,
“date”: “2018-08-14T11:31:59Z”
}

A really cool company

How does the template where you render the image look like?

The list.html looks as follows

{{ partial "header.html" . }}
{{ partial "subnavbar.html" . }}
<main>
  <div>
  {{.Render "summary"}}
   
        <ul>
            {{ range .Pages }}
                {{ .Render "li"}}
            {{ end }}
        </ul>
  </div>
</main>
{{ partial "footer.html" . }}

and the summary.html looks as follows

  `<img src='{{ .Params.logo}}'>`

I think render might assume some special characters are to be encoded and thus destroys your image.

I would use another approach. There is a function safecss that you use this way:

{{ .Params.logo | safeCSS }}

No guarantee that it works.

If it does not work my next try would be using the print function.

1 Like

tried both previously and again with no luck.
The print function outputs the correct string but it is not rendering correctly.

The following works but is not ideal

<img id="tt" src='{{ print .Params.logo}}'>
<script>
    document.getElementById("tt").src="{{print .Params.logo}}"
</script>

Interesting. This script does basically what the src parameter does. I checked caniuse.com for datauri and it seems that Internet Explorer and Firefox have issues with them.

They propose you urlencode the code. I don’t think Hugo has (yet?) a function like this, but the search in this forum brought up this:

Try:

{{ .Params.logo | safeURL }}

I wonder if that has issues because your string is not a URL… If that does not work I am out of ideas :wink: We’ll wait for someone else to come to help :slight_smile:

1 Like

Try removing the single quotes from the summary.html file or include the file as a partial and avoid Render.

You could also try piping to safeHTMLAttr as shown here.

FYI the single quotes were a copy issue. Did not exist in the file

However thaks for the lead I solved the issue.

I changed the .Params.logo to an array (probably did not need to)
and placed the following in my template

{{range .Params.logo}}
<img class=“mr-3” {{printf “src="%s"” . | safeHTMLAttr}} alt=“”>
{{end}}

3 Likes

Try:
{{ .Params.logo | safeURL }}

This solved a similar issue for me. Thanks :slight_smile:

1 Like

Yes this worked for me as well :slight_smile: