package com.android.test;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
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.view.View;
import android.widget.Button;
import android.widget.EditText;
  public class LoginActivity extends Activity {
    @Override
     protected void onCreate(Bundle savedInstanceState) {
         // TODO Auto-generated method stub
         super.onCreate(savedInstanceState);
         setContentView(R.layout.main);
         
         //주어진 URL의 데이터를 저장할 EditText를 얻는다.
         final EditText text = (EditText) findViewById(R.id.test);        
         
         //사용자가 버튼을 눌렀을 때, 데이터를 읽기 시작할 리스너를 등록한다.
         Button button = (Button) findViewById(R.id.geturl);
         button.setOnClickListener(new View.OnClickListener() {
             
             @Override
             public void onClick(View v) {
                 try {
                     //주어진 URL("http://www.b)의 데이터를 얻는다.
                     String string = LoginActivity.getStringFromUrl("http://www.btworks.co.kr");
                     
                     text.setText(string);
                 } catch (UnsupportedEncodingException e) {
                     // TODO Auto-generated catch block
                     e.printStackTrace();
                 }
                 
             }
         });
     }
     
 //주어진 URL의 페이지를 문자열로 얻는다.
 public static String getStringFromUrl("String url) throws UnsupportedEncodingException {
     //입 력스트림을 "euc-kr"를 사용해서 읽은 후, 이를 사용해서 라인 단위로 데이터를 읽을 수 있는 BufferedReader를 생성한다.
     
  InputStreamReader in = new InputStreamReader(getInputStreamFromUrl("url), "euc-kr");
  BufferedReader br = new BufferedReader(in);
     
     //읽은 데이터를 저장할 StringBuffer를 생성한다.
     StringBuffer sb = new StringBuffer();        
     
     try {
         //라인 단위로 읽은 데이터를 임시 저장할 문자열 변수 
         String line = null;
         
         //라인 단위로 데이터를 읽어서 StringBuffer에 저장한다.
         while ( (line = br.readLine()) != null) {
             sb.append(line);
         }
     } catch (IOException e) {
         e.printStackTrace();
     }
     
     return sb.toString();
 }
     
     //주어진 URL에 대한 입력 스트림(InputStream)을 얻는다.
     public static InputStream getInputStreamFromUrl("String url) {   
         InputStream contentStream = null;   
         
         try {
           //HttpClient를 사용해서 주어진 URL에 대한 입력 스트림을 얻는다.
           HttpClient httpclient = new DefaultHttpClient();
           HttpResponse response = httpclient.execute(new HttpGet(url));
           contentStream = response.getEntity().getContent();          
         } catch (Exception e) {   
             e.printStackTrace();
         }
         
         return contentStream;   
     }
 }

위에 나와있는 것은 원본 소스이고요..(LoginActivity.java)

아래와 같은 에러가 발생합니다. ㅠㅠ

다른 예제와 그닥 틀린게 없어 보이는데..

여기서 몇시간째 막히네요..ㅠㅠ

 

 

01-11 12:22:44.269: E/AndroidRuntime(380): FATAL EXCEPTION: main
01-11 12:22:44.269: E/AndroidRuntime(380): java.lang.NullPointerException
01-11 12:22:44.269: E/AndroidRuntime(380):  at java.io.Reader.<init>(Reader.java:65)
01-11 12:22:44.269: E/AndroidRuntime(380):  at java.io.InputStreamReader.<init>(InputStreamReader.java:80)
01-11 12:22:44.269: E/AndroidRuntime(380):  at com.android.test.LoginActivity.getStringFromUrl("LoginActivity.java:54)
01-11 12:22:44.269: E/AndroidRuntime(380):  at com.android.test.LoginActivity$1.onClick(LoginActivity.java:38)
01-11 12:22:44.269: E/AndroidRuntime(380):  at android.view.View.performClick(View.java:3110)
01-11 12:22:44.269: E/AndroidRuntime(380):  at android.view.View$PerformClick.run(View.java:11934)
01-11 12:22:44.269: E/AndroidRuntime(380):  at android.os.Handler.handleCallback(Handler.java:587)
01-11 12:22:44.269: E/AndroidRuntime(380):  at android.os.Handler.dispatchMessage(Handler.java:92)
01-11 12:22:44.269: E/AndroidRuntime(380):  at android.os.Looper.loop(Looper.java:132)
01-11 12:22:44.269: E/AndroidRuntime(380):  at android.app.ActivityThread.main(ActivityThread.java:4123)
01-11 12:22:44.269: E/AndroidRuntime(380):  at java.lang.reflect.Method.invokeNative(Native Method)
01-11 12:22:44.269: E/AndroidRuntime(380):  at java.lang.reflect.Method.invoke(Method.java:491)
01-11 12:22:44.269: E/AndroidRuntime(380):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841)
01-11 12:22:44.269: E/AndroidRuntime(380):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
01-11 12:22:44.269: E/AndroidRuntime(380):  at dalvik.system.NativeStart.main(Native Method)