Ampersands (&) in xlink:href attributes of SVG ima

2019-04-26 16:50发布

I'm building an SVG document which contains various image tags. The xlink:href (source URL) attributes for the images contain query strings with ampersands. If I escape them as %26 or the ascii encoding ? they're not valid query strings and the server won't deliver the image. I can't escape them with CDATA because they're attributes (not nodes). I've tried creating an xlink:href node within the image tag but that get's ignored by the SVG parser. I want to use pure SVG (not SVG within HTML) so that I can convert to a JPG later, thus scripting is out...

Any hints on how I can make the below work?

<image x="0" y="0" width="306" height="306" xlink:href="http://host.com/image.jpg?token=asdf&expiration=9384029&etc=etc"/>

Thanks!

2条回答
姐就是有狂的资本
2楼-- · 2019-04-26 17:32

In all XML applications, including SVG, the following entities are valid without a custom DTD:

  • &amp; - &
  • &gt; - >
  • &lt; - <

In your case, this should work without resorting to ugly ASCII hacks:

<image xlink:href="http://foo.com/bar.jpg?token=asdf&amp;exp=9384&amp;etc=etc"/>
查看更多
forever°为你锁心
3楼-- · 2019-04-26 17:39

The solution is to replace the ampersands with the correct ascii code #38 and Not #63 (which is a question mark '?') as I had initially tried after mis-reading this question: using "?" in SVG href

Thanks to Stunti https://stackoverflow.com/users/54949/stunti

http://www.ascii.cl/htmlcodes.htm

查看更多
登录 后发表回答