博客
关于我
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。

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

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

    你可能感兴趣的文章
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>
    NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
    查看>>
    NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
    查看>>
    NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
    查看>>
    NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>
    NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
    查看>>
    NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
    查看>>
    NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
    查看>>
    NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
    查看>>
    NIH发布包含10600张CT图像数据库 为AI算法测试铺路
    查看>>
    Nim教程【十二】
    查看>>
    Nim游戏
    查看>>
    NIO ByteBuffer实现原理
    查看>>
    Nio ByteBuffer组件读写指针切换原理与常用方法
    查看>>
    NIO Selector实现原理
    查看>>
    nio 中channel和buffer的基本使用
    查看>>
    NIO三大组件基础知识
    查看>>