洞察管理小程序实例的关键在于实现跨平台能力与数据安全,如何利用FinClip助力企业在数字化转型中既合规又高效?
602
2022-09-27
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.
开始还觉得很奇怪,怎么会就找不到模板文件呢?
仔细想下,想起不同系统的文件分隔符是不相同的:
获得系统名字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" ;
虽然问题很小,如果不注意所不定要花费很久去处理。还好想起系统分隔符的原因:
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~