私は、JSONオブジェクトからいくつかの値を読み込まなければならないAndroidアプリケーションを作っています。だから、JSONオブジェクトを取得し、それを読むために、私は次のメソッドを使用しています「権限が拒否されました」というエラーが表示されるのはなぜですか?
private void _init() {
_rates = new HashMap<String, String>();
URLConnection jsonURL = null;
InputStream in = null;
String jRatesStream = null;
try {
jsonURL = new URL(jRatesURL).openConnection();
jsonURL.connect(); // ERROR OCCURING HERE
in = jsonURL.getInputStream();
jRatesStream = _convertStreamToString(in);
} catch(Exception e) {
Log.v("ERROR", "ERROR WHILE READING URL", e);
} finally {
try {
in.close();
} catch (Exception e) {
}
}
try {
JSONObject jObject = new JSONObject(jRatesStream);
JSONObject jRates = jObject.getJSONObject("rates");
Iterator<String> iterator = jRates.keys();
while(iterator.hasNext()) {
String key = iterator.next();
_rates.put(key, String.valueOf(jRates.getDouble(key)));
}
} catch (Exception e) {
}
}
そしてjRatesURL
Stringこのです:
private static final String jRatesURL = "http://openexchangerates.org/latest.json";
しかし、この方法を実行するときに、私が拒否されました「許可を得ます"エラー:
ERROR WHILE READING URL
java.net.SocketException: Permission denied
at org.apache.harmony.luni.platform.OSNetworkSystem.createStreamSocketImpl(Native Method)
at org.apache.harmony.luni.platform.OSNetworkSystem.createStreamSocket(OSNetworkSystem.java:186)
at org.apache.harmony.luni.net.PlainSocketImpl.create(PlainSocketImpl.java:265)
at java.net.Socket.checkClosedAndCreate(Socket.java:873)
at java.net.Socket.connect(Socket.java:1020)
at org.apache.harmony.luni.internal.net.www.protocol.http.HttpConnection.<init>(HttpConnection.java:62)
at org.apache.harmony.luni.internal.net.www.protocol.http.HttpConnectionPool.get(HttpConnectionPool.java:88)
at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.getHTTPConnection(HttpURLConnectionImpl.java:927)
at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.connect(HttpURLConnectionImpl.java:909)
at com.testing.exchangerates.Rates._init(Rates.java:45)
at com.testing.exchangerates.Rates.<init>(Rates.java:27)
at com.testing.exchangerates.HomeActivity.onCreate(HomeActivity.java:27)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
at android.app.ActivityThread.access$2300(ActivityThread.java:125)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:123)
at android.app.ActivityThread.main(ActivityThread.java:4627)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:521)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
at dalvik.system.NativeStart.main(Native Method)
このエラーの原因は何ですか? JSONリンクに接続する際に何か問題がありますか?
大変助かりました。ありがとう!あなたはマニフェストで
<uses-permission android:name="android.permission.INTERNET" />
許可を
にその権限を使用してください。 – anddev
はい、それは問題でした!ありがとう.. – Roshnal