我已经看到的一些问题上如何编码的图像文件在base64,但如何对周围的其他方法-我怎么重新组建一个图片来自一个base64string存在XML文件?

<resource>
<data encoding="base64">
R0lGODlhEAAQAPMAMcDAwP/crv/erbigfVdLOyslHQAAAAECAwECAwECAwECAwECAwECAwECAwEC
AwECAyH/C01TT0ZGSUNFOS4wGAAAAAxtc09QTVNPRkZJQ0U5LjAHgfNAGQAh/wtNU09GRklDRTku
MBUAAAAJcEhZcwAACxMAAAsTAQCanBgAIf8LTVNPRkZJQ0U5LjATAAAAB3RJTUUH1AkWBTYSQXe8
fQAh+QQBAAAAACwAAAAAEAAQAAADSQhgpv7OlDGYstCIMqsZAXYJJEdRQRWRrHk2I9t28CLfX63d
ZEXovJ7htwr6dIQB7/hgJGXMzFApOBYgl6n1il0Mv5xuhBEGJAAAOw==
</data>
<mime>image/gif</mime>
<resource-attributes>
    <file-name>clip_image001.gif</file-name>
</resource-attributes>
</resource>

鉴于上述XML节点 resource, 怎么我去创造 clip_image001.gif?

请建议:

  1. XSLT处理和/或扩展使这一点,再加上
  2. 一样XSLT触发 转换

注意,它必须能够处理至少GIF&PNG文件格式。最好不局限于任何操作系统。


实现解决方案

根据周围 Mads汉森的 解决方案。主要区别是,我引用 net.sf.saxon.value.Base64BinaryValue 直接在我的名字空间,而不是使用 saxon 名字空间,因为我理解Java Api更直观地比Saxonica网站的说明 base64Binary-to-octetsbase64Binary 功能。

<xsl:stylesheet version="2.0" 
    xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:b64="net.sf.saxon.value.Base64BinaryValue"
    xmlns:fos="java.io.FileOutputStream"
    ...
    exclude-result-prefixes="b64 fos">
...
<xsl:for-each select="resource">                
    <xsl:variable name="b64" select="b64:new(string(data))"/>
    ...
    <xsl:variable name="fos" select="fos:new(string($img))"/>
    <xsl:value-of select="fos:write($fos, b64:getBinaryValue($b64))"/>  
    <xsl:value-of select="fos:close($fos)"/>
</xsl:for-each>
...

P.S.看看 兄弟姐妹的问题 对于我的执行情况如何获得哈希需要识别的图像文件。


这个问题是一个subquestion的 另一个问题,我已要求以前.

有帮助吗?

解决方案

我发现了这个项目从XSL maiing名单 这一介绍如何使用 撒克逊扩展功能 xs:base64Binary到八 流出来的一个文件使用Java FileOutputStream在XSLT2.0样式表:

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform";
version="2.0" xmlns:xs="http://www.w3.org/2001/XMLSchema";
xmlns:saxon="http://saxon.sf.net/";
xmlns:fos="java.io.FileOutputStream">
<xsl:template match="/">
   <xsl:variable name="img" select="concat('c:\test\jesper', '.jpg')"/>
   <xsl:variable name="fos" select="fos:new(string($img))"/>
   <xsl:value-of select="fos:write($fos,
saxon:base64Binary-to-octets(xs:base64Binary(my-base64-encoded-image)))"/>
   <xsl:value-of select="fos:close($fos)"/>
</xsl:template>
</xsl:stylesheet>

其他提示

以下工作:

<img>
  <xsl:attribute name="src">
    <xsl:value-of select="concat('data:image/gif;base64,',xPath)"/>
  </xsl:attribute>
</img>

把它改造为HTML。

<img src="data:{mime};base64,{data}" />

有一个更好的方法可用,因为撒克逊人的9.5通过EXPath文件的扩展模块(可在撒克逊-PE和萨克森-EE)。

这是一段代码我使用的抽取二进制的图像文件的词的文件(源XML是在WordProcessingML格式):

<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:file="http://expath.org/ns/file" xmlns:pkg="http://schemas.microsoft.com/office/2006/xmlPackage">

<xsl:template match="/pkg:package">
    <xsl:apply-templates select="pkg:part/pkg:binaryData"/>
</xsl:template>

<xsl:template match="pkg:binaryData">
    <xsl:variable name="filename">
        <xsl:value-of select="replace(../@pkg:name, '/word/media/', '')"/>
    </xsl:variable>
    <xsl:variable name="path" select="concat('/some/folder/', $filename)"/>
    <xsl:message><xsl:value-of select="$path"/></xsl:message>

    <xsl:value-of select="file:write-binary($path, xs:base64Binary(string()))"/>       
</xsl:template>
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top