如下:采用的是access数据库, 放在src目录下,数据库的配置信息Db.properties也放在src目录下:
driver=sun.jdbc.odbc.JdbcOdbcDriver
url =jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=src//myTest.mdb
user =
pwd = 不打包成jar档可以正常运行,打包成jar档url读取不到,请高手帮忙呀~
读取Db.properties:
InputStream is = getClass().getResourceAsStream("/Db.properties");
try{
load(is);
}catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
获取url信息:
String url =Conn.getInstance().getProperty("url") ,,(打包成jar档读取异常)
driver=sun.jdbc.odbc.JdbcOdbcDriver
url =jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=src//myTest.mdb
user =
pwd = 不打包成jar档可以正常运行,打包成jar档url读取不到,请高手帮忙呀~
读取Db.properties:
InputStream is = getClass().getResourceAsStream("/Db.properties");
try{
load(is);
}catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
获取url信息:
String url =Conn.getInstance().getProperty("url") ,,(打包成jar档读取异常)
加个.
试试
public static String getAppPath(Class cls)
{
//检查用户传入的参数是否为空
if(cls==null)
throw new java.lang.IllegalArgumentException("参数不能为空!");
ClassLoader loader=cls.getClassLoader();
//获得类的全名,包括包名
String clsName=cls.getName()+".class";
//获得传入参数所在的包
Package pack=cls.getPackage();
String path="";
//如果不是匿名包,将包名转化为路径
if(pack!=null)
{
String packName=pack.getName();
//此处简单判定是否是Java基础类库,防止用户传入JDK内置的类库
if(packName.startsWith("java.")||packName.startsWith("javax."))
throw new java.lang.IllegalArgumentException("不要传送系统类!");
//在类的名称中,去掉包名的部分,获得类的文件名
clsName=clsName.substring(packName.length()+1);
//判定包名是否是简单包名,如果是,则直接将包名转换为路径,
if(packName.indexOf(".")<0)
path=packName+"/";
else
{
//否则按照包名的组成部分,将包名转换为路径
int start=0,end=0;
end=packName.indexOf(".");
while(end!=-1)
{
path=path+packName.substring(start,end)+"/";
start=end+1;
end=packName.indexOf(".",start);
}
path=path+packName.substring(start)+"/";
}
}
//调用ClassLoader的getResource方法,传入包含路径信息的类文件名
java.net.URL url =loader.getResource(path+clsName);
//从URL对象中获取路径信息
String realPath=url.getPath();
//去掉路径信息中的协议名"file:"
int pos=realPath.indexOf("file:");
if(pos>-1) realPath=realPath.substring(pos+5);
//去掉路径信息最后包含类文件信息的部分,得到类所在的路径
pos=realPath.indexOf(path+clsName);
realPath=realPath.substring(0,pos-1);
//如果类文件被打包到JAR等文件中时,去掉对应的JAR等打包文件名
if(realPath.endsWith("!"))
realPath=realPath.substring(0,realPath.lastIndexOf("/"));
/*------------------------------------------------------------
ClassLoader的getResource方法使用了utf-8对路径信息进行了编码,当路径
中存在中文和空格时,他会对这些字符进行转换,这样,得到的往往不是我们想要
的真实路径,在此,调用了URLDecoder的decode方法进行解码,以便得到原始的
中文及空格路径
-------------------------------------------------------------*/
try
{
realPath=java.net.URLDecoder.decode(realPath,"utf-8");
}
catch(Exception e)
{
throw new RuntimeException(e);
}
return realPath;
}//getAppPath定义结束这个是获取指定class文件绝对路径的一个方法,我在这个基础上写了一个获取当前项目下任意文件绝对地址的工具类,但是不知道扔哪个角落里了,楼主你就将就用,改造一下,用来找自己的这个mdb文件。