博客
关于我
Java-很深我只知其一-路径获取/处理
阅读量:617 次
发布时间:2019-03-13

本文共 1118 字,大约阅读时间需要 3 分钟。

Java路径获取与处理指南

在Java开发过程中,路径处理是日常工作中的常见操作之一。本文将涵盖从获取容器根路径到处理绝对路径的详细方法。

获取发布容器的根路径

在获取Web项目的根路径时,可以通过以下步骤实现:

  • 使用request对象获取ServletContext:

    request.getSession().getServletContext().getRealPath("/")
    • 以上代码将返回当前应用程序的根路径,路径以操作系统的默认设备文件分隔符表示。
    • 若需在特定包名下获取路径,可将"/"替换为对应包名。
  • 获取以类路径为基准的绝对路径:

    当前类.class.getResource("/").toURI().getPath();
    • 若返回值为null,仅需去掉toURI层即可:
    当前类.class.getResource("/").getPath();
    • 此方法返回的是当前类所在路径,以jar文件的路径为基准。
  • 获取项目根目录

    要获取项目所在工作空间的根目录,可采用以下方法:

  • 使用系统属性:

    String path = System.getProperty("user.dir");
    • 这种方法适用于已知项目根路径时,简单直观。
  • 注意路径处理:

    • 不同操作系统使用不同的设备分隔符(/在Linux,\在Windows),处理时需统一使用File.separator进行处理,以提高代码的跨平台性。
  • 实战示例

    以下是一些实际开发中的路径处理案例,供参考:

    • 循环处理父目录

      假设需要获取当前类所在套uses的根路径,可以通过循环截取处理:

      URL resource = 当前类.class.getResource("...");  while (resource.getPath().contains ../) {      resource = resource.getParent();  }      resource.getPath();
    • 获取项目根目录

      有时需要访问项目的物理根目录,可以通过以下方式:

      String rootPath = new File(System.getProperty("user.dir")).getCanonicalPath();
      • 使用getCanonicalPath()可以获取绝对路径,去除相对性链接。

    总结

    路径处理是Java开发中的一个基础操作,熟练掌握这些方法能显著提升开发效率。在实际应用中,多注意路径的基础分隔符及跨平台性问题,以减少潜在bug。

    如需更深入的学习,可以结合实际项目进行实践,逐步掌握路径处理的技巧。

    注:本文为技术交流内容,仅供参考,未经授权不得转载。

    你可能感兴趣的文章
    【C/C++学院】(6)构造函数/析构函数/拷贝构造函数/深copy浅copy
    查看>>
    oracle rac 安装 PRVG-13606 ntp 同步报错解决过程
    查看>>
    Oracle RAC性能调整的方案
    查看>>
    oracle rac集群的东西之QQ聊天
    查看>>
    UML— 用例图
    查看>>
    Oracle Schema Objects——Tables——Table Compression
    查看>>
    oracle scott趣事
    查看>>
    oracle script
    查看>>
    Oracle select表要带双引号的原因
    查看>>
    Oracle SOA Suit Adapter
    查看>>
    Oracle Spatial GeoRaster 金字塔栅格存储
    查看>>
    Oracle spatial 周边查询SQL
    查看>>
    Oracle Spatial空间数据库建立
    查看>>
    UML— 活动图
    查看>>
    oracle sqlplus已停止工作,安装完成客户端后sqlplus报“段错误”
    查看>>
    oracle SQLserver 函数
    查看>>
    oracle sql分组(group,根据多个内容分组)在select之后from之前 再进行select查询,复杂子查询的使用
    查看>>
    UML— 时序图
    查看>>
    Oracle Statspack分析报告详解(一)
    查看>>
    oracle tirger_在Oracle中,临时表和全局临时表有什么区别?
    查看>>