Я пытаюсь скопировать фрагмент HttpURLConnection с страницы разработчика Android в мой проект, чтобы увидеть, могу ли я подключиться к Интернету, и каждый раз, когда я запускаю функцию, мое приложение закрывается. я не уверен, почему приложение терпит неудачу, и любая помощь будет оценена по достоинству. этот код помещаются внутри public class main extends Activity
отправка запроса http-url
Main.java:
public void showHelp() throws IOException {
URL url = new URL("http://www.android.com/");
HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();
try{
InputStream in = new BufferedInputStream(urlConnection.getInputStream());
//readStream(in);
} finally{
urlConnection.disconnect();
}
}
я закомментирована ReadStream, потому что я думал, что преобразование может быть проблема, но это еще не дело. эта функция:
private String readStream(InputStream is) {
try {
ByteArrayOutputStream bo = new ByteArrayOutputStream();
int i = is.read();
while(i != -1) {
bo.write(i);
i = is.read();
}
return bo.toString();
} catch (IOException e) {
return "";
}
}
если сообщение о лоте кошки помогает, пожалуйста, дайте мне знать. также я довольно новичок в программировании на Android, и первая функция вызывается при нажатии на пункт меню, но я не думаю, что это было важно. также
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
включены в андроида манифеста XML
ошибка LogCat:
02-04 21:27:14.468: W/dalvikvm(16978): threadid=1: thread exiting with uncaught exception (group=0x4208d2a0)
02-04 21:27:14.492: E/AndroidRuntime(16978): FATAL EXCEPTION: main
02-04 21:27:14.492: E/AndroidRuntime(16978): android.os.NetworkOnMainThreadException
02-04 21:27:14.492: E/AndroidRuntime(16978): at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1118)
02-04 21:27:14.492: E/AndroidRuntime(16978): at java.net.InetAddress.lookupHostByName(InetAddress.java:385)
02-04 21:27:14.492: E/AndroidRuntime(16978): at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)
02-04 21:27:14.492: E/AndroidRuntime(16978): at java.net.InetAddress.getAllByName(InetAddress.java:214)
02-04 21:27:14.492: E/AndroidRuntime(16978): at libcore.net.http.HttpConnection.<init>(HttpConnection.java:70)
02-04 21:27:14.492: E/AndroidRuntime(16978): at libcore.net.http.HttpConnection.<init>(HttpConnection.java:50)
02-04 21:27:14.492: E/AndroidRuntime(16978): at libcore.net.http.HttpConnection$Address.connect(HttpConnection.java:340)
02-04 21:27:14.492: E/AndroidRuntime(16978): at libcore.net.http.HttpConnectionPool.get(HttpConnectionPool.java:87)
02-04 21:27:14.492: E/AndroidRuntime(16978): at libcore.net.http.HttpConnection.connect(HttpConnection.java:128)
02-04 21:27:14.492: E/AndroidRuntime(16978): at libcore.net.http.HttpEngine.openSocketConnection(HttpEngine.java:315)
02-04 21:27:14.492: E/AndroidRuntime(16978): at libcore.net.http.HttpEngine.connect(HttpEngine.java:310)
02-04 21:27:14.492: E/AndroidRuntime(16978): at libcore.net.http.HttpEngine.sendSocketRequest(HttpEngine.java:289)
02-04 21:27:14.492: E/AndroidRuntime(16978): at libcore.net.http.HttpEngine.sendRequest(HttpEngine.java:239)
02-04 21:27:14.492: E/AndroidRuntime(16978): at libcore.net.http.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:273)
02-04 21:27:14.492: E/AndroidRuntime(16978): at libcore.net.http.HttpURLConnectionImpl.getInputStream(HttpURLConnectionImpl.java:168)
02-04 21:27:14.492: E/AndroidRuntime(16978): at com.MeadowEast.audiotest.MainActivity.showHelp(MainActivity.java:369)
02-04 21:27:14.492: E/AndroidRuntime(16978): at com.MeadowEast.audiotest.MainActivity.onOptionsItemSelected(MainActivity.java:97)
02-04 21:27:14.492: E/AndroidRuntime(16978): at android.app.Activity.onMenuItemSelected(Activity.java:2625)
02-04 21:27:14.492: E/AndroidRuntime(16978): at com.android.internal.policy.impl.PhoneWindow.onMenuItemSelected(PhoneWindow.java:1061)
02-04 21:27:14.492: E/AndroidRuntime(16978): at com.android.internal.view.menu.MenuBuilder.dispatchMenuItemSelected(MenuBuilder.java:735)
02-04 21:27:14.492: E/AndroidRuntime(16978): at com.android.internal.view.menu.MenuItemImpl.invoke(MenuItemImpl.java:149)
02-04 21:27:14.492: E/AndroidRuntime(16978): at com.android.internal.view.menu.MenuBuilder.performItemAction(MenuBuilder.java:874)
02-04 21:27:14.492: E/AndroidRuntime(16978): at com.android.internal.view.menu.ListMenuPresenter.onItemClick(ListMenuPresenter.java:179)
02-04 21:27:14.492: E/AndroidRuntime(16978): at android.widget.AdapterView.performItemClick(AdapterView.java:298)
02-04 21:27:14.492: E/AndroidRuntime(16978): at android.widget.AbsListView.performItemClick(AbsListView.java:1280)
02-04 21:27:14.492: E/AndroidRuntime(16978): at android.widget.AbsListView$PerformClick.run(AbsListView.java:3083)
02-04 21:27:14.492: E/AndroidRuntime(16978): at android.widget.AbsListView$1.run(AbsListView.java:3983)
02-04 21:27:14.492: E/AndroidRuntime(16978): at android.os.Handler.handleCallback(Handler.java:615)
02-04 21:27:14.492: E/AndroidRuntime(16978): at android.os.Handler.dispatchMessage(Handler.java:92)
02-04 21:27:14.492: E/AndroidRuntime(16978): at android.os.Looper.loop(Looper.java:137)
02-04 21:27:14.492: E/AndroidRuntime(16978): at android.app.ActivityThread.main(ActivityThread.java:4949)
02-04 21:27:14.492: E/AndroidRuntime(16978): at java.lang.reflect.Method.invokeNative(Native Method)
02-04 21:27:14.492: E/AndroidRuntime(16978): at java.lang.reflect.Method.invoke(Method.java:511)
02-04 21:27:14.492: E/AndroidRuntime(16978): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1043)
02-04 21:27:14.492: E/AndroidRuntime(16978): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:810)
02-04 21:27:14.492: E/AndroidRuntime(16978): at dalvik.system.NativeStart.main(Native Method)
новый код AsyncTask:
private abstract class myTask extends AsyncTask<String,Void,Void>{
protected void doInBackground(String addressName) throws IOException {
URL url = new URL(addressName);
HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();
try{
InputStream in = new BufferedInputStream(urlConnection.getInputStream());
//readStream(in);
} finally{
urlConnection.disconnect();
}
}
protected void onProgressUpdate() {
//do nothing
}
protected void onPostExecute() {
//toast me
}
}
вызывается из:
public void showHelp(){
new myTask().execute("http://www.android.com/");
}
я не могу загрузить на устройство Android я получаю эту проблему: Невозможно создать тип main.mytask
какая ошибка поживаешь? –
Опубликуйте свой логарифм. С какой версией Android вы тестируете? – rubenlop
сделано и Android 4.1.2 с целевым API19 – blu