2012-01-27 6 views
0

현재 Android에서 내 webservice에 연결하는 데 문제가 있습니다. 저는 Jetty 웹 서비스를 사용하고 ANT를 사용하여이를 구축하고 있습니다. 내 노트북에서 그것은 완벽하게 작동하고 내 데이터베이스에서 항목을 표시합니다. 그러나 그것은 내 안드로이드 응용 프로그램에 연결하지 않는 것 같습니다. 코드 및 LOGCAT 보고서가 첨부됩니다. 는 HTTP의 포장을 풀고에 오류가 발생하지 않습니다android를 통해 webservice에 연결하는 데 문제가 있습니다.

import java.io.BufferedReader; 
import java.io.InputStream; 
import java.io.InputStreamReader; 
import org.apache.http.HttpResponse; 
public class HttpUnpack { 
public static String request(HttpResponse response){ 
String result = ""; 
try{ InputStream in = response.getEntity().getContent(); 
BufferedReader reader = new BufferedReader(new InputStreamReader(in)); 
StringBuilder str = new StringBuilder(); 
String line = null; 
while((line = reader.readLine()) != null){ 
str.append(line + "\n"); 
} 
in.close(); 
result = str.toString(); 
}catch(Exception ex){ 
result = "Error retrieving response"; 
} 
return result; 
} 
} 

는 HTTP 포장 풀기 및 Android2Servlet 파일

import org.apache.http.HttpResponse; 
import org.apache.http.client.HttpClient; 
import org.apache.http.client.methods.HttpGet; 
import org.apache.http.impl.client.DefaultHttpClient; 
import android.app.Activity; 
import android.os.Bundle; 
import android.widget.EditText; 
import android.widget.TextView; 
public class Android2Servlet extends Activity { 
/** Called when the activity is first created. */ 
@Override 
public void onCreate(Bundle savedInstanceState) { 
super.onCreate(savedInstanceState); 
setContentView(R.layout.dbtest); 
TextView txtresp = (TextView)findViewById(R.id.servlet_response); 

String url = "http://(MY LAPTOPS IP):8085/DB"; 
HttpClient client = new DefaultHttpClient(); 
HttpGet request = new HttpGet(url); 
try{ 
System.out.println("About to execute"); 
HttpResponse response = client.execute(request); 
String helpedResp=HttpUnpack.request(response); 
System.out.println(helpedResp); 
txtresp.setText(helpedResp); 
System.out.println(response); 
}catch(Exception ex){ 
txtresp.setText("Failed!"); 
ex.printStackTrace(); 
} 
} } 

그러나 텍스트 상자는 "실패!"를 반환합니다.

로그 캣 파일

W/System.err(1282): android.os.NetworkOnMainThreadException 
W/System.err(1282):  at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1099) 
W/System.err(1282):  at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:84) 
W/System.err(1282):  at libcore.io.IoBridge.connectErrno(IoBridge.java:127) 
W/System.err(1282):  at libcore.io.IoBridge.connect(IoBridge.java:112) 
W/System.err(1282):  at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192) 
W/System.err(1282):  at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459) 
W/System.err(1282):  at java.net.Socket.connect(Socket.java:842) 
W/System.err(1282):  at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:119) 
W/System.err(1282):  at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:144) 
W/System.err(1282):  at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164) 
W/System.err(1282):  at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119) 
W/System.err(1282):  at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360) 
W/System.err(1282):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555) 
W/System.err(1282):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487) 
W/System.err(1282):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465) 
W/System.err(1282):  at myFood.myFood.Android2Servlet.onCreate(Android2Servlet.java:24) 
W/System.err(1282):  at android.app.Activity.performCreate(Activity.java:4465) 
W/System.err(1282):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049) 
W/System.err(1282):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920) 
W/System.err(1282):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981) 
W/System.err(1282):  at android.app.ActivityThread.access$600(ActivityThread.java:123) 
W/System.err(1282):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147) 
W/System.err(1282):  at android.os.Handler.dispatchMessage(Handler.java:99) 
W/System.err(1282):  at android.os.Looper.loop(Looper.java:137) 
W/System.err(1282):  at android.app.ActivityThread.main(ActivityThread.java:4424) 
W/System.err(1282):  at java.lang.reflect.Method.invokeNative(Native Method) 
W/System.err(1282):  at java.lang.reflect.Method.invoke(Method.java:511) 
W/System.err(1282):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) 
W/System.err(1282):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) 
W/System.err(1282):  at dalvik.system.NativeStart.main(Native Method) 

모든 응답은 크게 도움이 될 것입니다.

감사합니다.

편집 : 나는 이제 네트워크 액세스를 제거하고 다른 자바 클래스에 넣어 한

. 그리고 다른 클래스를 형성한다고합니다. 그리고 그것은 여전히 ​​같은 오류를 반환합니다. 다른 조언?

import org.apache.http.HttpResponse; 
import org.apache.http.client.HttpClient; 
import org.apache.http.client.methods.HttpGet; 
import org.apache.http.impl.client.DefaultHttpClient; 
public class androidconnectors { 

    public static final String main(String args[]) throws Exception { 


String txtresp = ""; 
try{ 
    String url = "http://(LAPTOPS IP):8085/Hello"; 
    HttpClient client = new DefaultHttpClient(); 
    HttpGet request = new HttpGet(url); 
System.out.println("About to execute"); 
HttpResponse response = client.execute(request); 
String helpedResp=HttpUnpack.request(response); // Http Unpack is not part of 
System.out.println(helpedResp); // of HttpClient library 
txtresp =(helpedResp); 
System.out.println(response); 
}catch(Exception ex){ 
    ex.printStackTrace(); 
} 
return txtresp; 
} 
} 

android 클래스.

import android.app.Activity; 
import android.os.Bundle; 
import android.view.View; 
import android.widget.Button; 
import android.widget.TextView; 

public class Settings extends Activity { 
    /** Called when the activity is first created. */ 
    @Override 
    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.dbtest); 
     Button mybutton = (Button) findViewById(R.id.buttonpress); 
     mybutton.setOnClickListener(new View.OnClickListener() { 
      public void onClick(View view) { 
       TextView txtresp = (TextView)findViewById(R.id.servlet_response); 
      String[] args = null; 
      try { 
       String x = androidconnectors.main(args); 
       txtresp.setText(x); 
      } catch (Exception e) { 
       // TODO Auto-generated catch block 
       e.printStackTrace(); 
       txtresp.setText("Failed"); 
      } 

      } 
     }); 
} 
} 

답변

2

허니 콤 이후 당신이 (응답 성을 향상시키기 위해) 앱의 주 스레드에서 네트워크 액세스를 실행 안되도록하는 quick google search을 기반으로 보인다.

제안대로 네트워크 액세스를위한 다른 스레드를 만듭니다.

+0

안녕하세요, 저는 애플리케이션에서 새 클래스를 만들려고했지만 (문제는 수정 해주세요), 여전히 동일한 문제가 있습니다. 간단한 오류가 있었거나 다시 작업해야합니까? – user1128488

+0

User1128488, 멀티 스레딩 문제를 해결하기 전에 기본 Java에 대한 읽기가 필요합니다. – Marcelo

+0

몇 가지 독서 후 실을 사용하여 그것을하는 방법을 알아 냈습니다. 조언 해주셔서 감사합니다. – user1128488

2
당신은 더 나은 AsyncTask/Service/IntentService

NetworkOnMainThreadException

응용 프로그램의 주 스레드에 네트워킹 작업을 수행하려고 할 때 throw되는 예외를 사용하는 UI 스레드에서 네트워크 운영을 할 수 없습니다

. (API 11 이후)

1

StrictMode 문제를 해결하려면 다음 코드를 사용해야합니다. ur 활동 -

static{ 
    StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build(); 
StrictMode.setThreadPolicy(policy); 
} 
관련 문제