本文共 5747 字,大约阅读时间需要 19 分钟。
阅读目录
本篇博客是 JavaWeb 应用服务器端在不同环境下获取文件路径的全面总结。
获取文件路径后主要应用的场景,读取 JavaWeb 自定义配置文件、在特定路径下生成各种类型的文件提供下载......
想必看官也是来找方法的,先看上面目录有没有能解决你问题的,如果有就点击进到对应小节,如果没有速度关闭,看搜索引擎列出来的下一条记录吧。
getServletContext().getRealPath("/");
output :E:\workspace\tree\ (tree是我web项目的根目录)
this.getClass().getClassLoader().getResource("/").getPath();Thread.currentThread().getContextClassLoader().getResource("/").getPath();
output : E:\workspace\tree\WEB-INF\classes\
request.getServletContext().getRealPath("/");
output:E:\Workspaces\tree\WebContent\
request.getRealPath("");
得到jbossWEB发布临时目录 warUrl=.../tmp/deploy/tmp14544test-exp.war/
path=C:\jboss-4.0.5.GA\server\default\tmp\deploy\tmp14544test-exp.war\(String)request.getContextPath();
得到项目(test)应用所在的真实的路径 path=/test
request.getRequestURI();
得到应用所在的真实的路径 path=/test/admin/admindex.jsp
request.getRealPath(request.getServletPath());
得到当前文件的磁盘绝对路径
new File(".").getAbsolutePath(); new File(".").getPath(); new File(application.getRealPath(request.getRequestURI())).getParent()
得到jboss运行目录 path=C:\jboss-4.0.5.GA\bin\
服务器端的相对地址指的是相对于你的web应用的地址。这个地址是在服务器端解析的(不同于html和javascript中的相对地址,他们是由客户端浏览器解析的)
也就是说这时候在jsp和servlet中的相对地址应该是相对于你的web应用,即相对于http: //192.168.0.1/webapp/的。
eg:
Forward:servlet中的request.getRequestDispatcher(address);这个address是在服务器端解析。你要forward到a.jsp应该这么写:request.getRequestDispatcher(“/user/a.jsp”)
这个/ 相对于当前的web应用webapp,其绝对地址就是:http://192.168.0.1/webapp/user/a.jsp。
sendRedirect:在jsp中<%response.sendRedirect("/rtccp/user/a.jsp");%>
所有的html页面中的相对地址都是相对于服务器根目录(http://192.168.0.1/)的,而不是(跟目录下的该Web应用的目录) http://192.168.0.1/webapp/的。
Html中的form表单的action属性的地址应该是相对于服务器根目录(http://192.168.0.1/)的。
如果提交到a.jsp 为:action="/webapp/user/a.jsp"或action="<%=request.getContextPath()% >"/user/a.jsp;
提交到servlet为actiom="/webapp/handleservlet" Javascript也是在客户端解析的,所以其相对路径和form表单一样。
因此,一般情况下,在JSP/HTML页面等引用的CSS,Javascript.Action等属性前面最好都加上<%=request.getContextPath()%>,以确保所引用的文件都属于Web应用中的目录。
另外,应该尽量避免使用类似".","./","../../"等类似的相对该文件位置的相对路径,这样当文件移动时,很容易出问题。
a.根目录所对应的绝对路径:request.getServletPath();
b.文件的绝对路径 :request.getSession().getServletContext().getRealPath(request.getRequestURI())
c.当前web应用的绝对路径 :servletConfig.getServletContext().getRealPath("/");
javax.servlet.http.HttpSession.getServletContext()javax.servlet.jsp.PageContext.getServletContext()javax.servlet.ServletConfig.getServletContext()
d..Java 的Class中获得相对路径,绝对路径的方法
根据java.io.File的Doc文挡,可知:默认情况下new File("/")代表的目录为:System.getProperty("user.dir")。
System.out.println(Thread.currentThread().getContextClassLoader().getResource("")); System.out.println(Test.class.getClassLoader().getResource("")); System.out.println(ClassLoader.getSystemResource("")); System.out.println(Test.class.getResource("")); System.out.println(Test.class.getResource("/")); System.out.println(new File("/").getAbsolutePath()); System.out.println(System.getProperty("user.dir"));
WebApplication的系统文件根目录是你的weblogic安装所在根目录。
例如:如果你的weblogic安装在c:beaweblogic700.....
那么,你的文件根路径就是c:
所以,有两种方式能够让你访问你的服务器端的文件。
使用绝对路径:比如将你的参数文件放在c:yourconfigyourconf.properties。
new FileInputStream("yourconfig/yourconf.properties");
使用相对路径:相对路径的根目录就是你的webapplication的根路径,即WEB-INF的上一级目录,将你的参数文件放在yourwebappyourconfigyourconf.properties,
new FileInputStream("./yourconfig/yourconf.properties");
b.Tomcat
在类中输出System.getProperty("user.dir");显示的是%Tomcat_Home%/bin
c.Resin
不是你的JSP放的相对路径,是JSP引擎执行这个JSP编译成SERVLET的路径为根.比如用新建文件法测试File f = new File("a.htm");
这个a.htm在resin的安装目录下
Java中取当前项目的根目录的方法
//因为类名为"Application",因此" Application.class"一定能找到 String result = Application.class.getResource("Application.class").toString(); int index = result.indexOf("WEB-INF"); if(index == -1)...{ index = result.indexOf("bin"); } result = result.substring(0,index); if(result.startsWith("jar"))...{ // 当class文件在jar文件中时,返回"jar:file:/F:/ ..."样的路径 result = result.substring(10); }else if(result.startsWith("file"))...{ // 当class文件在class文件中时,返回"file:/F:/ ..."样的路径 result = result.substring(6); } if(result.endsWith("/"))result = result.substring(0,result.length()-1);//不包含最后的"/" return result;
//js获取项目根路径,如: http://localhost:8083/uimcardprjfunction getRootPath(){ //获取当前网址,如: http://localhost:8083/uimcardprj/share/meun.jsp var curWwwPath=window.document.location.href; //获取主机地址之后的目录,如: uimcardprj/share/meun.jsp var pathName=window.document.location.pathname; var pos=curWwwPath.indexOf(pathName); //获取主机地址,如: http://localhost:8083 var localhostPaht=curWwwPath.substring(0,pos); //获取带"/"的项目名,如:/uimcardprj var projectName=pathName.substring(0,pathName.substr(1).indexOf('/')+1); return(localhostPaht+projectName);}
在任意class中使用到了getClassLoader():取得该Class对象的类装载器,对于classLoader 的认识还是在后续工作中接触后不断建立起来。
装载类的过程非常简单:查找类所在位置,并将找到的Java类的字节码装入内存,生成对应的Class对象。
Java的类装载器专门用来实现这样的过程,JVM并不止有一个类装载器,事实上,如果你愿意的话,你可以让JVM拥有无数个类装载器.
类装载器自身也是一个类,它也需要被装载到内存中来,那么这些类装载器由谁来装载呢,总得有个根吧?
确实存在这样的根,它就是神龙见首不见尾的Bootstrap ClassLoader. 为什么说它神龙见首不见尾呢?
因为你根本无法在Java代码中抓住哪怕是它的一点点的尾巴,
尽管你能时时刻刻体会到它的存在,因为java的运行环境所需要的所有类库,都由它来装载,而它本身是C++写的程序,可以独立运行,可以说是JVM的运行起点,颤抖吧,骚年!
在Bootstrap完成它的任务后,会生成一个AppClassLoader(实际上之前系统还会使用扩展类装载器ExtClassLoader,它用于装载Java运行环境扩展包中的类)。
这个类装载器才是我们经常使用的,可以调用ClassLoader.getSystemClassLoader() 来获得。
我们假定程序中没有使用类装载器相关操作设定或者自定义新的类装载器,那么我们编写的所有java类通通会由它来装载,值得尊敬吧。
AppClassLoader查找类的区域就是耳熟能详的Classpath,也是初学者必须跨过的门槛,有没有灵光一闪的感觉,我们按照它的类查找范围给它取名为类路径类装载器。
作者:
出处: 如果,您认为阅读这篇博客让您有些收获,不妨点击一下右下角的【推荐】 如果,您希望更容易地发现我的新博客,不妨点击一下左下角的【关注我】 如果,您对我的博客内容感兴趣,请继续关注我的后续博客,我是【Orson】 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段 声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。转载:http://www.cnblogs.com/java-class/p/5227423.html