Android uncaught обработчик / uncaught исключение - PullRequest
0 голосов
/ 21 ноября 2011

это мое первое приложение для Android, и я пытаюсь использовать сокеты для отправки текста со своего компьютера (сервера) на телефон (клиент).Я программировал на Java много раньше, но всегда с DrJava, а не с Eclipse, и это то, что я должен использовать для программирования на Android.

Следующий код - просто пример Java-программы, использующей сокеты, которые япросто добавил и удалил несколько строк и вставил его в код Android.Код находится здесь: http://zerioh.tripod.com/ressources/sockets.html Если вы не доверяете ссылкам, вы можете Google "пример сокета Java".Это должна быть первая ссылка.

Я получаю ошибку необнаруженного исключения, но я много раз просматривал код и не могу найти место без зацепки.Код работает с Java, но не с Android, поэтому я думаю, что это некоторая проблема с синтаксисом, специфичным для Android.

Вот код Android (клиент):

package com.example.helloandroid;

import android.app.Activity;
import android.widget.TextView;
import android.os.Bundle;
import java.io.*;
import java.net.Socket;
import java.net.UnknownHostException;

public class HelloAndroid extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    //TextView tv = new TextView(this);
    //tv.setText("Eclipse is a horrible program");
    Requester client = new Requester();
    client.run();
    //setContentView(tv);
}
}

class Requester{
Socket requestSocket;
ObjectOutputStream out;
ObjectInputStream in;
String message;
void run()
{
    try{
        //1. creating a socket to connect to the server
        requestSocket = new Socket("localhost", 2004);
        System.out.println("Connected to localhost in port 2004");
        //2. get Input and Output streams
        out = new ObjectOutputStream(requestSocket.getOutputStream());
        out.flush();
        in = new ObjectInputStream(requestSocket.getInputStream());
        //3: Communicating with the server
        try{
            message = (String)in.readObject();
            System.out.println("server>" + message);
            sendMessage("asdfjksajdflksjdklfjsdklfjlsdf");
            message = "bye";
            sendMessage(message);
        }
        catch(ClassNotFoundException classNot){
            System.err.println("data received in unknown format");
        }
    }
    catch(UnknownHostException unknownHost) {
        System.err.println("You are trying to connect to an unknown host!");
    }
    catch(IOException ioException) {
        ioException.printStackTrace();
    }
    finally{
        //4: Closing connection
        try{
            in.close();
            out.close();
            requestSocket.close();
        }
        catch(IOException ioException){
            ioException.printStackTrace();
        }
    }
}
void sendMessage(String msg)
{
    try{
        out.writeObject(msg);
        out.flush();
        System.out.println("client>" + msg);
    }
    catch(Exception e) {
        e.printStackTrace();
    }
    /*catch(IOException ioException){
        ioException.printStackTrace();
    }*/
}
}

Код сервератак же, как и на сайте.

Вот строки каталогов, которые, я думаю, актуальны.Если я пропустил некоторые из них, дайте мне знать, и я тоже опубликую их:

11-20 22:37:35.314: W/System.err(545): java.net.SocketException: Permission denied (maybe missing INTERNET permission)
11-20 22:37:35.324: W/System.err(545):  at org.apache.harmony.luni.platform.OSNetworkSystem.createStreamSocketImpl(Native Method)
11-20 22:37:35.324: W/System.err(545):  at org.apache.harmony.luni.platform.OSNetworkSystem.createStreamSocket(OSNetworkSystem.java:187)
11-20 22:37:35.324: W/System.err(545):  at org.apache.harmony.luni.net.PlainSocketImpl.create(PlainSocketImpl.java:266)
11-20 22:37:35.324: W/System.err(545):  at java.net.Socket.startupSocket(Socket.java:773)
11-20 22:37:35.324: W/System.err(545):  at java.net.Socket.tryAllAddresses(Socket.java:192)
11-20 22:37:35.324: W/System.err(545):  at java.net.Socket.<init>(Socket.java:256)
11-20 22:37:35.334: W/System.err(545):  at java.net.Socket.<init>(Socket.java:220)
11-20 22:37:35.334: W/System.err(545):  at com.example.helloandroid.Requester.run(HelloAndroid.java:33)
11-20 22:37:35.334: W/System.err(545):  at com.example.helloandroid.HelloAndroid.onCreate(HelloAndroid.java:19)
11-20 22:37:35.334: W/System.err(545):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
11-20 22:37:35.334: W/System.err(545):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2459)
11-20 22:37:35.334: W/System.err(545):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2512)
11-20 22:37:35.344: W/System.err(545):  at android.app.ActivityThread.access$2200(ActivityThread.java:119)
11-20 22:37:35.344: W/System.err(545):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1863)
11-20 22:37:35.344: W/System.err(545):  at android.os.Handler.dispatchMessage(Handler.java:99)
11-20 22:37:35.344: W/System.err(545):  at android.os.Looper.loop(Looper.java:123)
11-20 22:37:35.344: W/System.err(545):  at android.app.ActivityThread.main(ActivityThread.java:4363)
11-20 22:37:35.344: W/System.err(545):  at java.lang.reflect.Method.invokeNative(Native Method)
11-20 22:37:35.344: W/System.err(545):  at java.lang.reflect.Method.invoke(Method.java:521)
11-20 22:37:35.344: W/System.err(545):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
11-20 22:37:35.344: W/System.err(545):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
11-20 22:37:35.354: W/System.err(545):  at dalvik.system.NativeStart.main(Native Method)
11-20 22:37:35.354: D/AndroidRuntime(545): Shutting down VM
11-20 22:37:35.354: W/dalvikvm(545): threadid=3: thread exiting with uncaught exception (group=0x4001b188)
11-20 22:37:35.354: E/AndroidRuntime(545): Uncaught handler: thread main exiting due to uncaught exception
11-20 22:37:35.364: E/AndroidRuntime(545): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.helloandroid/com.example.helloandroid.HelloAndroid}: java.lang.NullPointerException
11-20 22:37:35.364: E/AndroidRuntime(545):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2496)
11-20 22:37:35.364: E/AndroidRuntime(545):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2512)
11-20 22:37:35.364: E/AndroidRuntime(545):  at android.app.ActivityThread.access$2200(ActivityThread.java:119)
11-20 22:37:35.364: E/AndroidRuntime(545):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1863)
11-20 22:37:35.364: E/AndroidRuntime(545):  at android.os.Handler.dispatchMessage(Handler.java:99)
11-20 22:37:35.364: E/AndroidRuntime(545):  at android.os.Looper.loop(Looper.java:123)
11-20 22:37:35.364: E/AndroidRuntime(545):  at android.app.ActivityThread.main(ActivityThread.java:4363)
11-20 22:37:35.364: E/AndroidRuntime(545):  at java.lang.reflect.Method.invokeNative(Native Method)
11-20 22:37:35.364: E/AndroidRuntime(545):  at java.lang.reflect.Method.invoke(Method.java:521)
11-20 22:37:35.364: E/AndroidRuntime(545):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
11-20 22:37:35.364: E/AndroidRuntime(545):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
11-20 22:37:35.364: E/AndroidRuntime(545):  at dalvik.system.NativeStart.main(Native Method)
11-20 22:37:35.364: E/AndroidRuntime(545): Caused by: java.lang.NullPointerException
11-20 22:37:35.364: E/AndroidRuntime(545):  at com.example.helloandroid.Requester.run(HelloAndroid.java:60)
11-20 22:37:35.364: E/AndroidRuntime(545):  at com.example.helloandroid.HelloAndroid.onCreate(HelloAndroid.java:19)
11-20 22:37:35.364: E/AndroidRuntime(545):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
11-20 22:37:35.364: E/AndroidRuntime(545):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2459)
11-20 22:37:35.364: E/AndroidRuntime(545):  ... 11 more
11-20 22:37:35.384: I/dalvikvm(545): threadid=7: reacting to signal 3
11-20 22:37:35.404: I/dalvikvm(545): Wrote stack trace to '/data/anr/traces.txt'

Когда я запускаю этот код на эмуляторе Android, он говорит: «Извините! Приложение ... неожиданно остановилось.Пожалуйста, попробуйте еще раз."Любая помощь будет оценена!Спасибо!

Ответы [ 3 ]

1 голос
/ 21 ноября 2011

добавьте этот тег

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

в манифест.

Требуется добавить разрешения на доступ к Интернету перед использованием его в приложении

0 голосов
/ 21 ноября 2011

Вам необходимо использовать разрешение ИНТЕРНЕТ в манифесте Android:

java.net.SocketException: Permission denied (maybe missing INTERNET permission)

И вы не получите исключение Nullpointer в случае, если in и out Потоки равны нулю в вашем предложении finally.Это null, так как они никогда не были открыты.

0 голосов
/ 21 ноября 2011

в соответствии с вашими журналами, вам необходимо добавить разрешение на использование Интернета.Объявите это в своем манифесте.

...