您的位置:首页 > 其它

web 服务中相对路径

2006-05-05 09:34 148 查看
      最近做web 服务的时候都用绝对路径,现在修改发现原来相对路径不是我想象的那么简单-参照物是class文件,网上有人说相对路径的起点不是class文件所在的路径,而是 java解释器所在的位置.你可以写一个生成文件的例子实验一下,得到路径是不同的,尤其是在使用web services调用一个生成文件的服务时,会发现生成的文件在system32目录下,这里就不多说了.

  最简单的方法就是得到一个类的绝对路径,根据这个类的路径,到./或././得到自己项目中的路径.网上找了几个人的程序如下

1

package my.samples.ser.infs;

import my.samples.ser.infs.test;
import java.io.File;
import java.io.IOException;
import java.net.MalformedURLException;
import java.net.URL;
import java.security.CodeSource;
import java.security.ProtectionDomain;

/**
 * @author 由月
 *
 * 这个类提供了一些根据类的class文件位置来定位的方法。
 */
public class Path {
 /**
  * 获取一个类的class文件所在的绝对路径。 这个类可以是JDK自身的类,也可以是用户自定义的类,或者是第三方开发包里的类。
  * 只要是在本程序中可以被加载的类,都可以定位到它的class文件的绝对路径。
  *
  * @param cls
  *            一个对象的Class属性
  * @return 这个类的class文件位置的绝对路径。 如果没有这个类的定义,则返回null。
  */
 public static String getPathFromClass(Class cls) throws IOException {
  String path = null;
  if (cls == null) {
   throw new NullPointerException();
  }
  URL url = getClassLocationURL(cls);
  if (url != null) {
   path = url.getPath();
   if ("jar".equalsIgnoreCase(url.getProtocol())) {
    try {
     path = new URL(path).getPath();
    } catch (MalformedURLException e) {
    }
    int location = path.indexOf("!/");
    if (location != -1) {
     path = path.substring(0, location);
    }
   }
   File file = new File(path);
   path = file.getCanonicalPath();
  }
  return path;
 }

 /**
  * 这个方法可以通过与某个类的class文件的相对路径来获取文件或目录的绝对路径。 通常在程序中很难定位某个相对路径,特别是在B/S应用中。
  * 通过这个方法,我们可以根据我们程序自身的类文件的位置来定位某个相对路径。
  * 比如:某个txt文件相对于程序的Test类文件的路径是../../resource/test.txt,
  * 那么使用本方法Path.getFullPathRelateClass("../../resource/test.txt",Test.class)
  * 得到的结果是txt文件的在系统中的绝对路径。
  *
  * @param relatedPath
  *            相对路径
  * @param cls
  *            用来定位的类
  * @return 相对路径所对应的绝对路径
  * @throws IOException
  *             因为本方法将查询文件系统,所以可能抛出IO异常
  */
 public static String getFullPathRelateClass(String relatedPath, Class cls)
   throws IOException {
  String path = null;
  if (relatedPath == null) {
   throw new NullPointerException();
  }
  String clsPath = getPathFromClass(cls);
  File clsFile = new File(clsPath);
  String tempPath = clsFile.getParent() + File.separator + relatedPath;
  File file = new File(tempPath);
  path = file.getCanonicalPath();
  return path;
 }

 /**
  * 获取类的class文件位置的URL。这个方法是本类最基础的方法,供其它方法调用。
  */
 private static URL getClassLocationURL(final Class cls) {
  if (cls == null)
   throw new IllegalArgumentException("null input: cls");
  URL result = null;
  final String clsAsResource = cls.getName().replace('.', '/').concat(
    ".class");
  final ProtectionDomain pd = cls.getProtectionDomain();
  // java.lang.Class contract does not specify
  // if 'pd' can ever be null;
  // it is not the case for Sun's implementations,
  // but guard against null
  // just in case:
  if (pd != null) {
   final CodeSource cs = pd.getCodeSource();
   // 'cs' can be null depending on
   // the classloader behavior:
   if (cs != null)
    result = cs.getLocation();

   if (result != null) {
    // Convert a code source location into
    // a full class file location
    // for some common cases:
    if ("file".equals(result.getProtocol())) {
     try {
      if (result.toExternalForm().endsWith(".jar")
        || result.toExternalForm().endsWith(".zip"))
       result = new URL("jar:".concat(
         result.toExternalForm()).concat("!/")
         .concat(clsAsResource));
      else if (new File(result.getFile()).isDirectory())
       result = new URL(result, clsAsResource);
     } catch (MalformedURLException ignore) {
     }
    }
   }
  }

  if (result == null) {
   // Try to find 'cls' definition as a resource;
   // this is not
   // document.d to be legal, but Sun's
   // implementations seem to //allow this:
   final ClassLoader clsLoader = cls.getClassLoader();
   result = clsLoader != null ? clsLoader.getResource(clsAsResource)
     : ClassLoader.getSystemResource(clsAsResource);
  }
  return result;
 }

public void aa()
{
   test t=new test();
//t.getPathFromClass(getClass());

//String url = getClass().getResource("test" + ".class");
//  System.out.println(t.getPathFromClass(getClass()));

}
 public static void main(String[] args) throws Exception
 {
  try {
   System.out.println(getPathFromClass(Path.class));
 //  System.out.println(getFullPathRelateClass("../test/abc/..",  Path.class));
  } catch (Exception e) {
   e.printStackTrace();
  }
 }

}

直接运行得到结果

C:/Tomcat/Tomcat%205.5/webapps/axis/WEB-INF/classes/my/samples/ser/infs/my/sampl
es/ser/infs

这个%20是个空格,怎么回事,在找一个程序测试

2

package my.samples.ser.infs;

import java.net.URL;
import java.io.*;

public class getPath
{
    /**
     * main
     *
     * @param args String[]
     */
//    public static void main(String[] args)
//    {
//        getPath getclasspath = new getPath();
//        System.out.println(getclasspath.getClassPath());
//    }

 /**
     * 在类中取得当前文件所在的相对路径与绝对路径
     *
     * @return String
     */
    public String getClassPath()
    {
        String strClassName = getClass().getName();
        String strPackageName = "";
        if(getClass().getPackage() != null)
        {
            strPackageName = getClass().getPackage().getName()
4000
;
        }

        String strClassFileName = "";
        if(!"".equals(strPackageName))
        {
            strClassFileName = strClassName.substring(strPackageName.length() + 1,strClassName.length());
        }
        else
        {
            strClassFileName = strClassName;
        }

        URL url = null;
        url = getClass().getResource(strClassFileName + ".class");
        String strURL = url.toString();
        strURL = strURL.substring(strURL.indexOf('/') + 1,strURL.lastIndexOf('/'));
        return strURL;
    }
   
    public static void main(String args[]) throws Exception
    {
     getPath p=new getPath();
     
         System.out.println(p.getClassPath());
    // String s=p.getClassPath();

   //s=java.net.URLDecoder.decode(s, "UTF-8");

      }
}

直接运行得到结果

C:/Tomcat/Tomcat%205.5/webapps/axis/WEB-INF/classes/my/samples/ser/infs/my/sampl
es/ser/infs

两个程序的结果一样,换了一个pc结果还是一样,看来是编码的问题

在第二个程序后面加了一句 

s=java.net.URLDecoder.decode(s, "UTF-8");

结果就正确了,空格就不会出现成%20了

参考文章

http://blog.csdn.net/youyue/archive/2005/03/22/326477.aspx



 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息