2012-02-23 23 views
1

私は、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" /> 

許可を

+0

にその権限を使用してください。 – anddev

+0

はい、それは問題でした!ありがとう.. – Roshnal

答えて

2

は、すべての必要な権限があるかどうかという点で、あなたたManifest.xmlファイルをチェックして、あなたのマニフェスト

<uses-permission android:name="android.permission.INTERNET"></uses-permission> 
+0

お返事ありがとうございました!それはエラーの原因でした..それは小さな問題だとは思わなかった:) – Roshnal

1

を与えられたことがありますか? here

String INTERNET Allows applications to open network sockets.

から

+0

はい、それは問題でした!ありがとうございますが、私は正しい答えとして他の答えを選んでいます。なぜなら、彼は最初に答えて、さらに多くの情報を持っていたからです。 – Roshnal

関連する問題