我正在在本文之后开发我的第一个标志。我已经读过其他几本,但是这对我来说似乎很简单/直观,特别是当我想做的事情比标志更大的事情时。
我必须对使用的PHP脚本进行一些更改。
更新我有两个php脚本,这是正确的脚本,最后一个是_get方法。
<?php
$con=mysql_connect("...");//deleted for privacy
mysql_select_db("..");//deleted for privacy
if (!$con)
{
echo "Failed to connect to MySQL: " . mysql_error();
die();
}
$username = $_POST['username'];
$password = $_POST['password'];
$query=mysql_query("SELECT username FROM users");
echo $query;echo $query;echo $query;echo $query;
if($query){
$row = mysql_fetch_assoc($query);
$data = $row['username'];
echo $data;
}else{
echo "something went wrong:".mysql_error();
}
mysql_close($con);
?>
在任何情况下,我都不认为错误在PHP中,因为我在浏览器上使用url中适当的用户名/密码中的适当值在浏览器上运行脚本,并且会打印出我要寻找的响应(这是只是用户名)。这是我修改的标志性。
package com.example.phpmysql;
public class LogInBackgroundActivity extends AsyncTask<String,Void,String>{
private Context context;
public AsyncResponse delegate=null;
public LogInBackgroundActivity(Context context) {
this.context=context;
}
@Override
protected String doInBackground(String... arg0) {
String address ="...";//hidden for privacy
try{
String username = (String)arg0[0];
String password = (String)arg0[1];
address+="login_post.php";
String data = URLEncoder.encode("username", "UTF-8") + "=" + URLEncoder.encode(username, "UTF-8");
data += "&" + URLEncoder.encode("password", "UTF-8") + "=" + URLEncoder.encode(password, "UTF-8");
URL url = new URL(address);
URLConnection conn = url.openConnection();
conn.setDoOutput(true);
OutputStreamWriter wr = new OutputStreamWriter(conn.getOutputStream());
wr.write( data );
wr.flush();
BufferedReader reader = new BufferedReader(new InputStreamReader(conn.getInputStream()));
StringBuilder sb = new StringBuilder();
String line = null;
// Read Server Response
while((line = reader.readLine()) != null){
sb.append(line);
break;
}
return sb.toString();
}catch(Exception e){
return new String("Exception: " + e.getMessage());
}
}
@Override
protected void onPostExecute(String result){
if(result.length()>0)
delegate.processFinished(result);
else
delegate.processFinished("Something Odd");
}
}
我从教程中了解的是,PHP脚本上打印的所有内容都会使用onPostExecute(..)
发送回。Asyncresponse只是我创建的界面,用于将这些数据运回主要活动。
这是我想要的数据,它回来了。
我正在在真实设备上测试,所以我没有logcat报告。
我使用了mysqli_*
,因为它在教程中使用,并且似乎已经解决了问题。