我有一个从项目的主文件夹加载config.properties文件的函数,但是,它给了我一个FileNotFoundException,我不明白为什么。 我的方法看起来像:
public static Configfile configuration() {
String server = null;
int dbport = 0;
String dbuser = null;
String dbpass = null;
Properties prop = new Properties();
InputStream input = null;
try {
input = new FileInputStream("config.properties");
prop.load(input);
server = prop.getProperty("server");
dbport = Integer.parseInt(prop.getProperty("dbport"));
dbuser = prop.getProperty("dbuser");
dbpass = prop.getProperty("dbpassword");
} catch (IOException ex) {
ex.printStackTrace();
} finally {
if (input != null) {
try {
input.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
return new Configfile(server, dbport, dbuser, dbpass);
}
我的config.properties文件位于:
E:\的Android \ NSomething5
我错过了什么?
编辑: 堆栈跟踪:
12-04 17:00:07.619: W/System.err(21368): java.io.FileNotFoundException: /config.properties: open failed: ENOENT (No such file or directory)
12-04 17:00:07.619: W/System.err(21368): at libcore.io.IoBridge.open(IoBridge.java:416)
12-04 17:00:07.619: W/System.err(21368): at java.io.FileInputStream.<init>(FileInputStream.java:78)
12-04 17:00:07.619: W/System.err(21368): at java.io.FileInputStream.<init>(FileInputStream.java:105)
12-04 17:00:07.619: W/System.err(21368): at com.example.nsomething.utils.DBOperations.configuration(DBOperations.java:122)
12-04 17:00:07.619: W/System.err(21368): at com.example.nsomething.utils.DBOperations.<init>(DBOperations.java:24)
12-04 17:00:07.619: W/System.err(21368): at com.example.nsomething.Report.<init>(Report.java:20)
12-04 17:00:07.619: W/System.err(21368): at java.lang.Class.newInstanceImpl(Native Method)
12-04 17:00:07.619: W/System.err(21368): at java.lang.Class.newInstance(Class.java:1319)
12-04 17:00:07.619: W/System.err(21368): at android.app.Instrumentation.newActivity(Instrumentation.java:1071)
12-04 17:00:07.619: W/System.err(21368): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2162)
12-04 17:00:07.619: W/System.err(21368): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2295)
12-04 17:00:07.619: W/System.err(21368): at android.app.ActivityThread.access$700(ActivityThread.java:150)
12-04 17:00:07.619: W/System.err(21368): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1280)
12-04 17:00:07.619: W/System.err(21368): at android.os.Handler.dispatchMessage(Handler.java:99)
12-04 17:00:07.619: W/System.err(21368): at android.os.Looper.loop(Looper.java:137)
12-04 17:00:07.619: W/System.err(21368): at android.app.ActivityThread.main(ActivityThread.java:5279)
12-04 17:00:07.619: W/System.err(21368): at java.lang.reflect.Method.invokeNative(Native Method)
12-04 17:00:07.619: W/System.err(21368): at java.lang.reflect.Method.invoke(Method.java:511)
12-04 17:00:07.619: W/System.err(21368): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
12-04 17:00:07.619: W/System.err(21368): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
12-04 17:00:07.619: W/System.err(21368): at dalvik.system.NativeStart.main(Native Method)
12-04 17:00:07.619: W/System.err(21368): Caused by: libcore.io.ErrnoException: open failed: ENOENT (No such file or directory)
12-04 17:00:07.619: W/System.err(21368): at libcore.io.Posix.open(Native Method)
12-04 17:00:07.619: W/System.err(21368): at libcore.io.BlockGuardOs.open(BlockGuardOs.java:110)
12-04 17:00:07.619: W/System.err(21368): at libcore.io.IoBridge.open(IoBridge.java:400)
12-04 17:00:07.619: W/System.err(21368): ... 20 more
答案 0 :(得分:2)
FileInputStream从绝对路径提供或相对于“当前工作目录”加载文件。现在绝对路径与您的示例无关。因此,FileInputStream在“当前工作目录”中搜索您的文件“config.properties”。该目录通常是您启动程序的目录。如果您在Android上执行此操作,请将配置文件放在te assets文件夹中,并使用assets API函数将文件作为流加载。如果这是一个独立的java程序,则将该文件放在classpath上,并使用classloader.getResourceAsStream加载该文件。最后,如果您知道文件的绝对路径,请直接使用它。
答案 1 :(得分:1)
E:\Android\NSomething5
这不是有效的Android文件系统路径。这是一个Windows路径。您设备上的应用与您电脑上的文件无关。
将配置文件放在项目的assets文件夹中。然后在运行时使用assetsmanager打开一个InputStream并从中读取。对于其余的,您可以使用相同的代码。只打开InputStream是不同的。