Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/196.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 如何修改此代码使其在Android API 3.0上工作?_Java_Android_Eclipse_Json_Android Asynctask - Fatal编程技术网

Java 如何修改此代码使其在Android API 3.0上工作?

Java 如何修改此代码使其在Android API 3.0上工作?,java,android,eclipse,json,android-asynctask,Java,Android,Eclipse,Json,Android Asynctask,我们正在制作一个Android应用程序,它具有登录功能,并且mySQL数据库存储在服务器上。我找到了一段代码,并让它在低于API级别3.0的Android设备上正常工作。除此之外的任何东西都会崩溃。我被告知使用Asynctask来解决我的问题。要将UI代码与网络代码分离?有人告诉我这应该很容易,但我不知道如何让它工作。有人能告诉我我需要做什么才能使代码正常工作吗?我花了无数个小时研究这个问题,但仍然没有成功。谢谢你的帮助。多谢各位 public class RegisterActivity ex

我们正在制作一个Android应用程序,它具有登录功能,并且mySQL数据库存储在服务器上。我找到了一段代码,并让它在低于API级别3.0的Android设备上正常工作。除此之外的任何东西都会崩溃。我被告知使用Asynctask来解决我的问题。要将UI代码与网络代码分离?有人告诉我这应该很容易,但我不知道如何让它工作。有人能告诉我我需要做什么才能使代码正常工作吗?我花了无数个小时研究这个问题,但仍然没有成功。谢谢你的帮助。多谢各位

public class RegisterActivity extends Activity {
Button btnRegister;
Button btnLinkToLogin;
EditText inputFullName;
EditText inputEmail;
EditText inputPassword;
TextView registerErrorMsg;

// JSON Response node names
private static String KEY_SUCCESS = "success";
private static String KEY_ERROR = "error";
private static String KEY_ERROR_MSG = "error_msg";
private static String KEY_UID = "uid";
private static String KEY_NAME = "name";
private static String KEY_EMAIL = "email";
private static String KEY_CREATED_AT = "created_at";

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.register);

    // Importing all assets like buttons, text fields
    inputFullName = (EditText) findViewById(R.id.registerName);
    inputEmail = (EditText) findViewById(R.id.registerEmail);
    inputPassword = (EditText) findViewById(R.id.registerPassword);
    btnRegister = (Button) findViewById(R.id.btnRegister);
    btnLinkToLogin = (Button) findViewById(R.id.btnLinkToLoginScreen);
    registerErrorMsg = (TextView) findViewById(R.id.register_error);

    // Register Button Click event
    btnRegister.setOnClickListener(new View.OnClickListener() {
        public void onClick(View view) {
            String name = inputFullName.getText().toString();
            String email = inputEmail.getText().toString();
            String password = inputPassword.getText().toString();
            UserFunctions userFunction = new UserFunctions();
            JSONObject json = userFunction.registerUser(name, email, password);

            // check for login response
            try {
                if (json.getString(KEY_SUCCESS) != null) {
                    registerErrorMsg.setText("");
                    String res = json.getString(KEY_SUCCESS);
                    if(Integer.parseInt(res) == 1){
                        // user successfully registred
                        // Store user details in SQLite Database
                        DatabaseHandler db = new DatabaseHandler(getApplicationContext());
                        JSONObject json_user = json.getJSONObject("user");

                        // Clear all previous data in database
                        userFunction.logoutUser(getApplicationContext());
                        db.addUser(json_user.getString(KEY_NAME), json_user.getString(KEY_EMAIL), json.getString(KEY_UID), json_user.getString(KEY_CREATED_AT));
                        // Launch Dashboard Screen
                        Intent dashboard = new Intent(getApplicationContext(), DashboardActivity.class);
                        // Close all views before launching Dashboard
                        dashboard.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
                        startActivity(dashboard);
                        // Close Registration Screen
                        finish();
                    }else{
                        // Error in registration
                        registerErrorMsg.setText("Error occured in registration");
                    }
                }
            } catch (JSONException e) {
                e.printStackTrace();
            }
        }
    });

    // Link to Login Screen
    btnLinkToLogin.setOnClickListener(new View.OnClickListener() {

        public void onClick(View view) {
            Intent i = new Intent(getApplicationContext(),
                    LoginActivity.class);
            startActivity(i);
            // Close Registration View
            finish();
        }
    });
}
}
这也是日志错误

 D/AndroidRuntime(10040): Shutting down VM
 W/dalvikvm(10040): threadid=1: thread exiting with uncaught exception (group=0x416f2930)
 E/AndroidRuntime(10040): FATAL EXCEPTION: main
 E/AndroidRuntime(10040): android.os.NetworkOnMainThreadException
 E/AndroidRuntime(10040):    at     android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1117)
 E/AndroidRuntime(10040):    at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:84)
 E/AndroidRuntime(10040):    at libcore.io.IoBridge.connectErrno(IoBridge.java:127)
 E/AndroidRuntime(10040):    at libcore.io.IoBridge.connect(IoBridge.java:112)
 E/AndroidRuntime(10040):    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
 E/AndroidRuntime(10040):    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459)
 E/AndroidRuntime(10040):    at java.net.Socket.connect(Socket.java:842)

从ICS及以上版本来看,Android不允许在UI线程中进行任何网络操作。它应该在单独的线程中进行,这样就不会挂起UI。请在单独的线程中尝试您的网络通信代码。


请参阅此内容。它解释了为什么Android 3.0及以上版本会出现这种情况。

确实,Android对UI线程变得非常严格,不允许您在UI线程上执行后台计算,因为这会降低性能。您被告知使用异步任务执行网络通信是正确的。您可以使用
newyourtask().execute()
;,在单击注册按钮时执行asyncTask

然后像这样编写一个asyncTask类

private class yourTask extends AsyncTask<Integer, Void, Integer> {
    @Override
    protected void onPreExecute() {
        super.onPreExecute();
        //show a progress bar 
    }

    @Override
    protected String doInBackground(Integer... params) {
       // your network communication code will be here.
        return 0; 
    }      

    @Override
    protected void onPostExecute(Integer result) {
        super.onPostExecute(result);
       //show the result here
    }
}
yourTask扩展AsyncTask的私有类{
@凌驾
受保护的void onPreExecute(){
super.onPreExecute();
//显示进度条
}
@凌驾
受保护字符串doInBackground(整数…参数){
//您的网络通信代码将在这里。
返回0;
}      
@凌驾
受保护的void onPostExecute(整数结果){
super.onPostExecute(结果);
//在这里显示结果
}
}
请参见此链接