权限被拒绝 - 缺少INTERNET权限? [英] Permission denied - missing INTERNET permission?

查看:444
本文介绍了权限被拒绝 - 缺少INTERNET权限?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我在与互联网的权限问题。是的,我环顾四周,我确信许可是应用程序标记之外。

I'm having problem with the internet permission. Yes I've looked around and I made sure the permission is outside the application tag.

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="app.com.example.android.sunshine" >

    <uses-permission android:name="android.permission.internet" />

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name=".MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest> 

和这里的logcat的:

And here's the logcat:

02-13 15:10:07.622 5879-5951 / app.com.example.android.sunshine
  E / AndroidRuntime:致命的异常:AsyncTask的#1
      工艺:app.com.example.android.sunshine,PID:5879
      了java.lang.RuntimeException:执行doInBackground发生错误()
              在android.os.AsyncTask $ 3.done(AsyncTask.java:300)
              在java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355)
              在java.util.concurrent.FutureTask.setException(FutureTask.java:222)
              在java.util.concurrent.FutureTask.run(FutureTask.java:242)
              在android.os.AsyncTask $ SerialExecutor $ 1.run(AsyncTask.java:231)
              在java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
              在java.util.concurrent.ThreadPoolExecutor中的$ Worker.run(ThreadPoolExecutor.java:587)
              在java.lang.Thread.run(Thread.java:841)
       java.lang.SecurityException异常:引起权限被拒绝(缺少INTERNET权限?)
              在java.net.InetAddress.lookupHostByName(InetAddress.java:418)
              在java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)
              在java.net.InetAddress.getAllByName(InetAddress.java:214)
              在com.android.okhttp.internal.Dns $ 1.getAllByName(Dns.java:28)
              在com.android.okhttp.internal.http.RouteSelector.resetNextInetSocketAddress(RouteSelector.java:216)
              在com.android.okhttp.internal.http.RouteSelector.next(RouteSelector.java:122)
              在com.android.okhttp.internal.http.HttpEngine.connect(HttpEngine.java:292)
              在com.android.okhttp.internal.http.HttpEngine.sendSocketRequest(HttpEngine.java:255)
              在com.android.okhttp.internal.http.HttpEngine.sendRequest(HttpEngine.java:206)
              在com.android.okhttp.internal.http.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:345)
              在com.android.okhttp.internal.http.HttpURLConnectionImpl.connect(HttpURLConnectionImpl.java:89)
              在app.com.example.android.sunshine.ForecastFragment$FetchWeatherTask.doInBackground(ForecastFragment.java:117)
              在app.com.example.android.sunshine.ForecastFragment$FetchWeatherTask.doInBackground(ForecastFragment.java:94)
              在android.os.AsyncTask $ 2.call(AsyncTask.java:288)
              在java.util.concurrent.FutureTask.run(FutureTask.java:237)
  在android.os.AsyncTask $ SerialExecutor $ 1.run(AsyncTask.java:231)
  在java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
  在java.util.concurrent.ThreadPoolExecutor中的$ Worker.run(ThreadPoolExecutor.java:587)
  在java.lang.Thread.run(Thread.java:841)
       libcore.io.GaiException:引起的getaddrinfo失败:EAI_NODATA(不与主机名关联的地址)
              在libcore.io.Posix.getaddrinfo(本机方法)
              在libcore.io.ForwardingOs.getaddrinfo(ForwardingOs.java:61)
              在java.net.InetAddress.lookupHostByName(InetAddress.java:405)
  在java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)
  在java.net.InetAddress.getAllByName(InetAddress.java:214)
  在com.android.okhttp.internal.Dns $ 1.getAllByName(Dns.java:28)
  在com.android.okhttp.internal.http.RouteSelector.resetNextInetSocketAddress(RouteSelector.java:216)
  在com.android.okhttp.internal.http.RouteSelector.next(RouteSelector.java:122)
  在com.android.okhttp.internal.http.HttpEngine.connect(HttpEngine.java:292)
  在com.android.okhttp.internal.http.HttpEngine.sendSocketRequest(HttpEngine.java:255)
  在com.android.okhttp.internal.http.HttpEngine.sendRequest(HttpEngine.java:206)
  在com.android.okhttp.internal.http.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:345)
  在com.android.okhttp.internal.http.HttpURLConnectionImpl.connect(HttpURLConnectionImpl.java:89)
   在app.com.example.android.sunshine.ForecastFragment$FetchWeatherTask.doInBackground(ForecastFragment.java:117)
   在app.com.example.android.sunshine.ForecastFragment$FetchWeatherTask.doInBackground(ForecastFragment.java:94)
  在android.os.AsyncTask $ 2.call(AsyncTask.java:288)
  在java.util.concurrent.FutureTask.run(FutureTask.java:237)
  在android.os.AsyncTask $ SerialExecutor $ 1.run(AsyncTask.java:231)
  在java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
  在java.util.concurrent.ThreadPoolExecutor中的$ Worker.run(ThreadPoolExecutor.java:587)
  在java.lang.Thread.run(Thread.java:841)
       libcore.io.ErrnoException:引起的getaddrinfo失败:EACCES(权限被拒绝)
  在libcore.io.Posix.getaddrinfo(本机方法)
  在libcore.io.ForwardingOs.getaddrinfo(ForwardingOs.java:61)
  在java.net.InetAddress.lookupHostByName(InetAddress.java:405)
  在java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)
  在java.net.InetAddress.getAllByName(InetAddress.java:214)
  在com.android.okhttp.internal.Dns $ 1.getAllByName(Dns.java:28)
  在com.android.okhttp.internal.http.RouteSelector.resetNextInetSocketAddress(RouteSelector.java:216)
  在com.android.okhttp.internal.http.RouteSelector.next(RouteSelector.java:122)
  在com.android.okhttp.internal.http.HttpEngine.connect(HttpEngine.java:292)
  在com.android.okhttp.internal.http.HttpEngine.sendSocketRequest(HttpEngine.java:255)
  在com.android.okhttp.internal.http.HttpEngine.sendRequest(HttpEngine.java:206)
  在com.android.okhttp.internal.http.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:345)
  在com.android.okhttp.internal.http.HttpURLConnectionImpl.connect(HttpURLConnectionImpl.java:89)
   在app.com.example.android.sunshine.ForecastFragment$FetchWeatherTask.doInBackground(ForecastFragment.java:117)
   在app.com.example.android.sunshine.ForecastFragment$FetchWeatherTask.doInBackground(ForecastFragment.java:94)
  在android.os.AsyncTask $ 2.call(AsyncTask.java:288)
  在java.util.concurrent.FutureTask.run(FutureTask.java:237)
  在android.os.AsyncTask $ SerialExecutor $ 1.run(AsyncTask.java:231)
  在java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
  在java.util.concurrent.ThreadPoolExecutor中的$ Worker.run(ThreadPoolExecutor.java:587)
  在java.lang.Thread.run(Thread.java:841)02-13 15:15:07.659 5879-5951 / app.com.example.android.sunshine I /工艺:
  发送信号。 PID:5879 SIG:9

02-13 15:10:07.622 5879-5951/app.com.example.android.sunshine E/AndroidRuntime﹕ FATAL EXCEPTION: AsyncTask #1 Process: app.com.example.android.sunshine, PID: 5879 java.lang.RuntimeException: An error occured while executing doInBackground() at android.os.AsyncTask$3.done(AsyncTask.java:300) at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355) at java.util.concurrent.FutureTask.setException(FutureTask.java:222) at java.util.concurrent.FutureTask.run(FutureTask.java:242) at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587) at java.lang.Thread.run(Thread.java:841) Caused by: java.lang.SecurityException: Permission denied (missing INTERNET permission?) at java.net.InetAddress.lookupHostByName(InetAddress.java:418) at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236) at java.net.InetAddress.getAllByName(InetAddress.java:214) at com.android.okhttp.internal.Dns$1.getAllByName(Dns.java:28) at com.android.okhttp.internal.http.RouteSelector.resetNextInetSocketAddress(RouteSelector.java:216) at com.android.okhttp.internal.http.RouteSelector.next(RouteSelector.java:122) at com.android.okhttp.internal.http.HttpEngine.connect(HttpEngine.java:292) at com.android.okhttp.internal.http.HttpEngine.sendSocketRequest(HttpEngine.java:255) at com.android.okhttp.internal.http.HttpEngine.sendRequest(HttpEngine.java:206) at com.android.okhttp.internal.http.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:345) at com.android.okhttp.internal.http.HttpURLConnectionImpl.connect(HttpURLConnectionImpl.java:89) at app.com.example.android.sunshine.ForecastFragment$FetchWeatherTask.doInBackground(ForecastFragment.java:117) at app.com.example.android.sunshine.ForecastFragment$FetchWeatherTask.doInBackground(ForecastFragment.java:94) at android.os.AsyncTask$2.call(AsyncTask.java:288) at java.util.concurrent.FutureTask.run(FutureTask.java:237)             at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)             at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)             at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)             at java.lang.Thread.run(Thread.java:841) Caused by: libcore.io.GaiException: getaddrinfo failed: EAI_NODATA (No address associated with hostname) at libcore.io.Posix.getaddrinfo(Native Method) at libcore.io.ForwardingOs.getaddrinfo(ForwardingOs.java:61) at java.net.InetAddress.lookupHostByName(InetAddress.java:405)             at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)             at java.net.InetAddress.getAllByName(InetAddress.java:214)             at com.android.okhttp.internal.Dns$1.getAllByName(Dns.java:28)             at com.android.okhttp.internal.http.RouteSelector.resetNextInetSocketAddress(RouteSelector.java:216)             at com.android.okhttp.internal.http.RouteSelector.next(RouteSelector.java:122)             at com.android.okhttp.internal.http.HttpEngine.connect(HttpEngine.java:292)             at com.android.okhttp.internal.http.HttpEngine.sendSocketRequest(HttpEngine.java:255)             at com.android.okhttp.internal.http.HttpEngine.sendRequest(HttpEngine.java:206)             at com.android.okhttp.internal.http.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:345)             at com.android.okhttp.internal.http.HttpURLConnectionImpl.connect(HttpURLConnectionImpl.java:89)             at app.com.example.android.sunshine.ForecastFragment$FetchWeatherTask.doInBackground(ForecastFragment.java:117)             at app.com.example.android.sunshine.ForecastFragment$FetchWeatherTask.doInBackground(ForecastFragment.java:94)             at android.os.AsyncTask$2.call(AsyncTask.java:288)             at java.util.concurrent.FutureTask.run(FutureTask.java:237)             at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)             at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)             at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)             at java.lang.Thread.run(Thread.java:841) Caused by: libcore.io.ErrnoException: getaddrinfo failed: EACCES (Permission denied)             at libcore.io.Posix.getaddrinfo(Native Method)             at libcore.io.ForwardingOs.getaddrinfo(ForwardingOs.java:61)             at java.net.InetAddress.lookupHostByName(InetAddress.java:405)             at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)             at java.net.InetAddress.getAllByName(InetAddress.java:214)             at com.android.okhttp.internal.Dns$1.getAllByName(Dns.java:28)             at com.android.okhttp.internal.http.RouteSelector.resetNextInetSocketAddress(RouteSelector.java:216)             at com.android.okhttp.internal.http.RouteSelector.next(RouteSelector.java:122)             at com.android.okhttp.internal.http.HttpEngine.connect(HttpEngine.java:292)             at com.android.okhttp.internal.http.HttpEngine.sendSocketRequest(HttpEngine.java:255)             at com.android.okhttp.internal.http.HttpEngine.sendRequest(HttpEngine.java:206)             at com.android.okhttp.internal.http.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:345)             at com.android.okhttp.internal.http.HttpURLConnectionImpl.connect(HttpURLConnectionImpl.java:89)             at app.com.example.android.sunshine.ForecastFragment$FetchWeatherTask.doInBackground(ForecastFragment.java:117)             at app.com.example.android.sunshine.ForecastFragment$FetchWeatherTask.doInBackground(ForecastFragment.java:94)             at android.os.AsyncTask$2.call(AsyncTask.java:288)             at java.util.concurrent.FutureTask.run(FutureTask.java:237)             at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)             at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)             at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)             at java.lang.Thread.run(Thread.java:841) 02-13 15:15:07.659 5879-5951/app.com.example.android.sunshine I/Process﹕ Sending signal. PID: 5879 SIG: 9

感谢您的帮助。

推荐答案

请使用:

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

请在这里阅读:

<一个href=\"http://stackoverflow.com/questions/17360924/securityexception-permission-denied-missing-internet-permission\">SecurityException:权限被拒绝(缺少INTERNET权限?)

根据你在做什么,你可能需要添加:

Depending on what you are doing you may need to add:

<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>

官方文档:<一href=\"http://developer.android.com/reference/android/Manifest.permission.html\">http://developer.android.com/reference/android/Manifest.permission.html

这篇关于权限被拒绝 - 缺少INTERNET权限?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆