我是android developpement的新手,我不知道我错过了什么让代码工作。尝试创建登录应用程序。我收到数据或使用dataoutputstream发送数据的方式有问题吗?有没有更好的方式,不被弃用和复杂。寻找最简约易懂的解决方案。
在后台代码中执行
@Override
protected Boolean doInBackground(String... params) {
DataOutputStream printout;
HttpURLConnection urlConn;
BufferedReader reader;
URL url;
String json;
JSONObject jObj;
//send POST login details to server
try {
url = new URL(SERVER_ADDRESS + "login.php");
urlConn = (HttpURLConnection) url.openConnection();
urlConn.setRequestMethod("POST");
urlConn.setDoOutput(true);
urlConn.setRequestProperty("Accept-Charset", "UTF-8");
urlConn.setReadTimeout(10000);
urlConn.setConnectTimeout(15000);
HashMap<String, String> map = new HashMap<String, String>();
map.put("username", params[0]);
map.put("password", params[1]);
StringBuilder sb = new StringBuilder();
for(HashMap.Entry<String, String> e : map.entrySet()){
if(sb.length() > 0){
sb.append("&");
}
sb.append(URLEncoder.encode(e.getKey(), "UTF-8")).append("=").append(URLEncoder.encode(e.getValue(), "UTF-8"));
}
String loginDetails = sb.toString();
printout = new DataOutputStream(urlConn.getOutputStream());
printout.writeBytes(loginDetails);
printout.flush();
printout.close();
reader = new BufferedReader(new InputStreamReader(urlConn.getInputStream()));
StringBuilder sb2 = new StringBuilder();
String result = null;
while((result=reader.readLine())!=null) {
sb2.append(result + '\n');
Log.d("Results", sb2.toString());
};
json = result.toString();
jObj = new JSONObject(json);
JSONLogin = jObj.getBoolean(TAG_LOGINSTATUS);
Log.d("LoginStatus!!!!", JSONLogin.toString());
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (ProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (JSONException e) {
Log.d("JsonConvertion", "FAILED TO CONVERT JSON");
}
return JSONLogin;
}
堆叠错误
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: FATAL EXCEPTION: AsyncTask #1
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: Process: com.httpkhronolog.khronolog, PID: 2459
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: java.lang.RuntimeException: An error occurred while executing doInBackground()
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: at android.os.AsyncTask$3.done(AsyncTask.java:309)
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:354)
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: at java.util.concurrent.FutureTask.setException(FutureTask.java:223)
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: at java.util.concurrent.FutureTask.run(FutureTask.java:242)
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:234)
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113)
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588)
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: at java.lang.Thread.run(Thread.java:818)
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String java.lang.String.toString()' on a null object reference
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: at com.httpkhronolog.khronolog.Login_Activity$checkUserDetails.doInBackground(Login_Activity.java:137)
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: at com.httpkhronolog.khronolog.Login_Activity$checkUserDetails.doInBackground(Login_Activity.java:79)
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: at android.os.AsyncTask$2.call(AsyncTask.java:295)
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: at java.util.concurrent.FutureTask.run(FutureTask.java:237)
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:234)
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113)
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588)
10-18 22:43:34.169 2459-2523/? E/AndroidRuntime: at java.lang.Thread.run(Thread.java:818)
的login.php
<?php
if($_SERVER["REQUEST_METHOD"] == "POST"){
// Establishing Connection with Server by passing server_name, user_id and password as a parameter
$connection = mysql_connect("localhost", "someusername", "Password");
// Selecting Database
$db = mysql_select_db("khronolo_systemdb", $connection);
$username = $_POST["username"];
$password = $_POST["password"];
$query = "SELECT * FROM user_table WHERE password='$password' AND email='$username';";
$result = mysql_query($query, $connection) or die (mysql_error($connection));
$rows = mysql_num_rows($result);
if ($rows == 1) {
$returnValue[] = array("loginStatus"=> "true");
echo json_encode($returnValue);
}
else {
$returnValue[] = array("loginStatus"=> "false");
echo json_encode($returnValue);
}
mysql_close($connection);
}
?>
答案 0 :(得分:1)
使用Volley 来自Google的网络库。请按照此tutorial进行操作。要了解有关Volley的更多信息,请参阅此link
还有其他网络库,如okHttp。
到目前为止,您的代码被认为是:
在第137行用json = result.toString();
替换json = sb2.toString();
答案 1 :(得分:0)
而不是
json = result.toString();
你应该做
json = sb2.toString();
退出时你的while循环,结果将为null,因此执行result.toString()
会导致nullpointerexception。
您可以使用GSON库来帮助您获得/设置响应值,而不会遇到任何障碍。