0

我正在开发一个在 Plone 网站内运行的 Applet。在 Plone 管理的其中一个页面中,我必须运行这个小程序,它执行以下步骤:

  • 高级表单验证

  • 在服务器硬盘上获取一个 excel 模板并将其复制并附加一些作为名称的数据(如 calcoloOneri.xls 变为 calcoloOneriJohnFileOne.xls)

  • 将表单数据写入新创建的文件

  • 将此文件发送到我创建的用于将 excel 转换为 PDF 的 Web 服务

  • 让用户在他们的机器上下载 pdf

现在的问题是,由于我可能有多个不同网站的实例,仅在名称和其他方面有所不同,因此我将我的小程序参数化为在这些不同场景中的每一个中运行。我特别注意了 template.xls 文件的位置,它可能会根据站点结构/文件名的需要而有所不同。加载小程序的代码如下(取自加载的页面):

<script src="http://www.java.com/js/deployJava.js"></script>
<script>var user='admin'</script>
<script>var comune='Andria'</script>
<script>var numPratica=''</script>
<script>var numPreinoltro='20482109022013'</script>
<script>var classifica=''</script>
<script>var numFascicolo=''</script>
<script>var annoFascicolo=''</script>
<script>var portalURL='http://xx.xx.xx.xx:xxxx/scia2'</script>
<script>
  var attributes = {code:'geotel.gui.Login.class', archive:'portal_url/++resource++java/GestioneOneri.jar, portal_url/++resource++java/mysql-connector-java-5.1.20-bin.jar, portal_url/++resource++java/poi-3.8-20120326.jar, portal_url/++resource++java/forms-1.3.0.jar', width:1024, height:700};
  var parameters = {jnlp_href:'portal_url/++resource++java/gestioneoneri.jnlp', nomeUtente:user, integrato:'true', portalUrl:portalURL, comune:comune, percorsoFileCalcoloOneri:'/++resource++java/', nomeFileCalcoloOneri:'calcoloOneri.xls', numPreinoltro:numPreinoltro, numPratica:numPratica, classifica:classifica, numFascicolo:numFascicolo, annoFascicolo:annoFascicolo};
  var version = '1.6';
  deployJava.runApplet(attributes, parameters, version);
</script>
<noscript>
Niente plugin java!
</noscript>

正如我从 Plone 文档中读到的,++resource++ 语法允许 CMS 检索在 xml 注册表中注册的静态资源,并且我将它用于 plone .pt 文件没有问题。

因此,在阅读完所有内容后,我前往浏览器并写道:

http://xx.xx.xx.xx:xxxx/scia2/++resource++java/calcoloOneri.xls

Chrome 会下载文件 calcoloOneri.xls,所以我认为“我必须走在正确的轨道上”。

当我将这些值传递到我的小程序中时,问题就出现了。首先,因为我可以有多个站点运行这个小程序,所以我将网站的地址作为参数(portalUrl)获取。为了检索 excel 文件的位置,我将 ++resource++java/calcoloOneri.xls 附加到门户 url,因为在浏览器中这个地址是正确的。

在我的 copyFile 方法中,我使用以下对象将 excel 模板复制到一个新模板中:

File f1 = new File(srFile); //srFile is "http://xx.xx.xx.xx:xxxx/scia2/++resource++java/calcoloOneri.xls"
File f2 = new File(dtFile);
InputStream in = new FileInputStream(f1);
OutputStream out = new FileOutputStream(f2);
byte[] buf = new byte[1024];
int len;
while((len = in.read(buf)) > 0)
{
   out.write(buf, 0, len);
}
in.close();
out.close();

我在我的皮肤上体验到 java.io.File 无法处理这种 url,我也无法在我的 applet 代码中使用 URL 或 URI 对象获取指向该文件的指针。

如何获得正确的字符串以将模板读入我的小程序?我错过了什么?

谢谢

4

1 回答 1

2

您最好在 python 中使用 xlwt 库来修改 excel 文档。然后,它可以是一个简单的 Web 表单。excel 模板可以是文件内容类型对象,因此您只需从那里对文件数据进行分级,而不是进行远程调用。

否则,您可以这样做的一种方法是硬编码 excel 模板文件的路径。

如果您想从 URL 下载文件,谷歌搜索可以提供帮助:http ://cookbooks.adobe.com/post_Download_a_file_from_a_URL_in_Java-17947.html

无论您如何解决它,在实施时都要小心,因为接受从 Internet 下载的用户提交的值可能很危险。

于 2013-02-27T23:32:04.747 回答