window 导出正常,linux导出有问题

今天遇到个bug。


这是个导出功能,使用的是POI,使用已经做好的模板,向里面添加数据,在action中进行处理。
首先取得模板,
路径:
\\export\\excel\\template\\temp.xls

代码:
String modelpath = getRequest().getSession().getServletContext().getRealPath("/")+ CommonConstants.MODEL_PATH;

我电脑使用的win7系统。以上代码我在本地tomcat测试,很正常。导出一点问题没有。
当提交到测试组,测试就报出bug:
java.io.FileNotFoundException: /usr/local/apache-tomcat-5.5.23/webapps/项目名称\export\excel\template\temp.xls (No such file or directory)
 at java.io.FileInputStream.open(Native Method)
 at java.io.FileInputStream.<init>(FileInputStream.java:106)
 at java.io.FileInputStream.<init>(FileInputStream.java:66)
 at com.stock.wrhcheck.web.StockCheckAction.exportExcel(StockCheckAction.java:85)
 。。。。。。



开始还觉得很奇怪,怎么会就找不到模板文件呢?
仔细想下,想起不同系统的文件分隔符是不相同的:
获得系统名字

System.out.println(System.getProperty( "os.name "));

----------------------------

获得系统文件分隔符

System.out.println(System.getProperty("file.separator"));  

文件分隔符,各个操作系统不一样  
  如WIndows的是"\",而Unix的是"/"


修改成下面就没问题了:
String modelpath = getRequest().getSession().getServletContext().getRealPath(CommonConstants.FILESEPARATOR)+ CommonConstants.MODEL_PATH;
public static final String FILESEPARATOR = System.getProperty("file.separator");
public static final String MODEL_PATH =FILESEPARATOR+"export"+FILESEPARATOR+"excel"+FILESEPARATOR+"template"+FILESEPARATOR+"temp.xls" ;


虽然问题很小,如果不注意所不定要花费很久去处理。还好想起系统分隔符的原因:

你可能感兴趣的:(java,tomcat,linux,Excel,OS)