InetAddress.getAllByName () ЗАБЛОКИРОВАНО - PullRequest
3 голосов
/ 27 мая 2019

Я недавно столкнулся с проводным вопросом.У меня есть устройство Android, которое подключило Wi-Fi, я уверен, что Wi-Fi в порядке.но устройство Android не может получить доступ к Интернету.Затем я обнаружил, что что-то не так с разрешением DNS, вот что я сделал.

1.Я написал приложение, которое просто вызывает метод InetAddress.getAllByName("www.google.com") в MainActivity.

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    new Thread(new Runnable() {
        @Override
        public void run() {
            try {
                Log.d("DNSTEST", "here >>> 0");
                InetAddress[] addresses = InetAddress.getAllByName("www.google.com");
                Log.d("DNSTEST", "here >>> 1");
                if (addresses != null) {
                    Log.d("DNSTEST", "here >>> 2");
                    for (InetAddress address : addresses) {
                        Log.d("DNSTEST", "here >>> 3");
                        Log.d("DNSTEST", "address: " + address.getHostAddress());
                    }
                }
                Log.d("DNSTEST", "here >>> 4");
            } catch (UnknownHostException e) {
                e.printStackTrace();
            }
        }
    }).start();
}

Вот вывод logcat:

2019-05-27 11:14:36.710 5204-5221/com.upward.dns D/DNSTEST: here >>> 0

Как видите, он блокируется при выполненииInetAddress.getAllByName("www.google.com").

2.Затем я написал исполняемую программу с использованием C ++ и попытался определить, не заблокирован ли он при выполнении на Android напрямую.

/*
 * dns.cpp
 *
 *  Created on: May 27, 2019
 *  Author: Will Tang
 */
#include<cstdio>
#include<netdb.h>
#include<arpa/inet.h>

int main()
{
    printf("here >>> 0\n");
    struct hostent *hptr = gethostbyname("www.google.com");

    printf("here >>> 1\n");
    char** pptr = hptr->h_addr_list;

    printf("here >>> 2\n");
    char str[32] = {0};

    printf("here >>> 3\n");
    for (; *pptr != nullptr; pptr++) {
        printf("here >>> 4\n");
        printf("address: %s\n", inet_ntop(hptr->h_addrtype, *pptr, str, sizeof(str)));
    }

    printf("done\n");
}

Создайте исходный код для исполняемой программы «DNS», затем вставьте его вКаталог SD-карты Android, затем выполните его.enter image description here

Все нормально! 3.Затем я написал общую библиотеку с тем же кодом C ++ и использую JNI, чтобы позволить java вызывать код C ++.

#include "com_upward_dns_DNSTest.h"
#include <android/log.h>
#include <thread>
#include <netdb.h>
#include <arpa/inet.h>

#define TAG "DNSTEST"
#define printf(...) __android_log_print(ANDROID_LOG_DEBUG, TAG, __VA_ARGS__)


JNIEXPORT void JNICALL Java_com_upward_dns_DNSTest_test(JNIEnv *env, jobject obj, jint count)
{
    printf("here >>> 0");
    struct hostent *hptr = gethostbyname("www.google.com");

    printf("here >>> 1");
    char** pptr = hptr->h_addr_list;

    printf("here >>> 2");
    char str[32] = {0};

    printf("here >>> 3");
    for (; *pptr != nullptr; pptr++) {
        printf("here >>> 4");
        printf("address: %s\n", inet_ntop(hptr->h_addrtype, *pptr, str, sizeof(str)));
    }

    printf("done");
}

package com.upward.dns;

public class DNSTest {

    static {
        System.loadLibrary("dns");
    }

    public native void test();

}
2019-05-27 11:41:18.694 5860-5860/com.upward.dns D/DNSTEST_JNI: here >>> 0

Плохие новости. Он заблокирован.Кто-нибудь может дать мне несколько советов?Спасибо!

...