Spring 获取web根目录

传统的方式:

private HttpServletRequest request;  
 // 文件保存路径  
String filePath = request.getSession().getServletContext().getRealPath("/") + "upload/";

// 转存文件  
file.transferTo(new File(filePath, file.getOriginalFilename()));  

spring默认会以webapp.root为key保存webapp的根路径
可以这样获取:

System.getProperty("webapp.root")

更改其配置,可在web.xml中的<web-app>节点内加入:

    <!-- webRoot根路径key值配置 -->  
    <context-param>    
        <param-name>webAppRootKey</param-name>     
        <param-value>tansungWeb.root</param-value>    
    </context-param>    
    <listener>     
        <listener-class>org.springframework.web.util.WebAppRootListener</listener-class>     
    </listener>  

然后在普通的Java类中(不是action中),就可以通过<code>System.getProperty("tansungWeb.root")</code>获取了web根目录了。

需要注意的是遮掩配置过后,在配置log4j日志文件保存路劲是就要把获取webroot根路径的key要相应改变为tansungWeb.root。

具体改变请看斜线处:

#debug < info < warn < error < fatal  
log4j.rootLogger=debug,stdout,logfile  
log4j.logger.cn.hydom.ztc=debug  
  
log4j.appender.stdout=org.apache.log4j.ConsoleAppender  
log4j.appender.stdout.Target=System.out  
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout  
log4j.appender.stdout.layout.ConversionPattern=%p [%l] %n---> %m%n  
#log4j.appender.stdout.layout.ConversionPattern=- [%p](%l) ---> [%m]%d{yyyy-MMM-dd   
  
HH:mm:ss}%n  
  
  
log4j.appender.logfile=org.apache.log4j.RollingFileAppender  
  
  
----------------------------------------------------------------------------  
#这是以前的配置  spring默认会以webapp.root为key保存webapp的根路径  
#log4j.appender.logfile.File=${webapp.root}/logs/sys.log  
#由于有了以上的配置,所以这里需要改变为${tansungWeb.root}  
log4j.appender.logfile.File=${tansungWeb.root}/logs/log.log  
-----------------------------------------------------------------------------  
  
log4j.appender.logfile.MaxFileSize=1MB  
# Keep three backup files.  
log4j.appender.logfile.MaxBackupIndex=10  
# Pattern to output: date priority [category] - message  
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout  
log4j.appender.logfile.layout.ConversionPattern= %n - [%p]-%d{yyyy-MMM-dd HH:mm:ss}-  
  
(%l)%n---> [%m]%n  
  
  
  
  
  
  
#ibatis logger config  
log4j.logger.com.ibatis=debug  
log4j.logger.com.ibatis.common.jdbc.SimpleDataSource=debug  
log4j.logger.com.ibatis.common.jdbc.ScriptRunner=debug  
log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate=debug  
log4j.logger.java.sql.Connection=debug  
log4j.logger.java.sql.Statement=debug  
log4j.logger.java.sql.PreparedStatement=debug  

然后再拼凑路径的时候,最好不要直接使用/或者\,最好使用File.separatorChar

这样的做法,适用于Spring配置中启动的线程需要获取web目录。例如删除临时文件的线程,定时发送邮件的线程。

http://blog.csdn.net/u013614451/article/details/39437571

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,969评论 19 139
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,959评论 6 342
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,767评论 18 399
  • 一 点点回国上二年级,第一课造句,例句:我在树林里走来走去,想寻找一片最美的枫...
    一江春水1990阅读 260评论 2 0
  • 2017年7月26日 聚焦网初五原创 张婷 郑州 分享第五十四天 星期三 北京 学心理学最近的体会...
    心愿幸福阅读 226评论 0 0