应用程序冻结和UI阻止

时间:2011-01-25 08:31:17

标签: android

HY!

我有2个班级:

主:

    public class Main extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //setContentView(R.layout.main);
       startActivityForResult(new Intent(Main.this, Login.class), 1);

    }
}

登录:

public class Login extends Activity{
    ProgressDialog pd = null;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        super.onCreate(savedInstanceState);
        setContentView(R.layout.login);

        final EditText user = (EditText)findViewById(R.id.login_etuser);
        final EditText pw = (EditText)findViewById(R.id.login_etpw);
        Button btlogin = (Button)findViewById(R.id.login_btlog);
        final Thread thread = new Thread (){
            public void run() {
                try
                {
                String result = "";
                result = postData(user.getText().toString(),pw.getText().toString());

                final JSONObject jObject = new JSONObject(result);
                JSONObject menuObject = jObject.getJSONObject("responseData");
                Log.e("XXX", menuObject.getString("session_id"));

                //pd.dismiss();
                }
                catch (Exception e)
                {
                    Log.e("XXX", e.getMessage());
                }



            };
        };

        btlogin.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {

                if (!user.getText().toString().equals("") && !pw.getText().toString().equals(""))
                {

                    thread.run();

                }

            }
        });
    }
    public String postData(final String user, final String pw) {
        // Create a new HttpClient and Post Header
        HttpClient httpclient = new DefaultHttpClient();
        HttpPost httppost = new HttpPost("http://surfkid.redio.de/login");
        String result;
        BufferedReader in = null;

        try {
            // Add your data
            List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>(2);
            nameValuePairs.add(new BasicNameValuePair("username", user));
            nameValuePairs.add(new BasicNameValuePair("password", md5(pw)));
            httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));

            // Execute HTTP Post Request
            HttpResponse response = httpclient.execute(httppost);
            if(response != null){
                in = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));

                StringBuffer sb = new StringBuffer("");
                String line = "";
                String NL = System.getProperty("line.separator");
                while ((line = in.readLine()) != null) {
                    sb.append(line + NL);
                }
                in.close();

                result = sb.toString();
                return result;
              }

        } catch (ClientProtocolException e) {
             Log.e("xxx", e.getMessage());
        } catch (IOException e) {
            Log.e("xxx", e.getMessage());
        }
        return null;
    }
     private String md5(String in) {

            MessageDigest digest;

            try {

                digest = MessageDigest.getInstance("MD5");

                digest.reset();        

                digest.update(in.getBytes());

                byte[] a = digest.digest();

                int len = a.length;

                StringBuilder sb = new StringBuilder(len << 1);

                for (int i = 0; i < len; i++) {

                    sb.append(Character.forDigit((a[i] & 0xf0) >> 4, 16));

                    sb.append(Character.forDigit(a[i] & 0x0f, 16));

                }

                return sb.toString();

            } catch (NoSuchAlgorithmException e) { e.printStackTrace(); }

            return null;

        }



}

logcat的:

01-25 09:24:57.641: ERROR/AndroidRuntime(31148): FATAL EXCEPTION: main
01-25 09:24:57.641: ERROR/AndroidRuntime(31148): java.lang.NullPointerException: println needs a message
01-25 09:24:57.641: ERROR/AndroidRuntime(31148):     at android.util.Log.println_native(Native Method)
01-25 09:24:57.641: ERROR/AndroidRuntime(31148):     at android.util.Log.e(Log.java:215)
01-25 09:24:57.641: ERROR/AndroidRuntime(31148):     at android.skiptvad.Login$1.run(Login.java:59)
01-25 09:24:57.641: ERROR/AndroidRuntime(31148):     at android.skiptvad.Login$2.onClick(Login.java:75)
01-25 09:24:57.641: ERROR/AndroidRuntime(31148):     at android.view.View.performClick(View.java:2461)
01-25 09:24:57.641: ERROR/AndroidRuntime(31148):     at android.view.View$PerformClick.run(View.java:8888)
01-25 09:24:57.641: ERROR/AndroidRuntime(31148):     at android.os.Handler.handleCallback(Handler.java:587)
01-25 09:24:57.641: ERROR/AndroidRuntime(31148):     at android.os.Handler.dispatchMessage(Handler.java:92)
01-25 09:24:57.641: ERROR/AndroidRuntime(31148):     at android.os.Looper.loop(Looper.java:123)
01-25 09:24:57.641: ERROR/AndroidRuntime(31148):     at android.app.ActivityThread.main(ActivityThread.java:4627)
01-25 09:24:57.641: ERROR/AndroidRuntime(31148):     at java.lang.reflect.Method.invokeNative(Native Method)
01-25 09:24:57.641: ERROR/AndroidRuntime(31148):     at java.lang.reflect.Method.invoke(Method.java:521)
01-25 09:24:57.641: ERROR/AndroidRuntime(31148):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858)
01-25 09:24:57.641: ERROR/AndroidRuntime(31148):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
01-25 09:24:57.641: ERROR/AndroidRuntime(31148):     at dalvik.system.NativeStart.main(Native Method)

请帮助!!!

Click on Button中的Thread.start有什么问题?

1 个答案:

答案 0 :(得分:2)

我认为menuObject.getString("session_id")e.getMessage()null

此外,我认为您要使用thread.start();而不是thread.run();Thread documentation