自己要做一个Android App,涉及到服务器端,以及Android客户端之间的交互,而网络上的的资源往往是只讲一个方面。所以自己每完成一段工作,会将开发过程记录下来,并供大家参考,相关文章放在专栏
【php + MySQL + Android】。
如果你遇到了什么问题,或者有好的建议,欢迎在评论区留言,或者私信我,大家一起交流。
😹作者也是小白,期待与你一起成长。
------------------------------------------------------------------------独学而无友, 则孤陋而寡闻
服用须知 🚀🚀🚀 本文中用到的Url链接你也可以用,如果你没有自己的服务器的话用来验证的账号密码:(这是作者数据库中的内容)
🚀🚀🚀遇到不懂的一定一定记得看专栏中前面的内容,这个项目是从零开始,连续记录的。没有的代码全在前面。 🚀🚀🚀🚀🚀有任何问题都可以私信我。
目录
前言
功能描述:
预备知识(建议有看不懂的再回来点相应的链接进去学习)
重难知识点整理:
Json
Toast
Http获取返回有延时
代码
功能描述: 手机上输入账号和密码将账号和密码发送到服务器服务器在MySql中查询输入的账号密码是否存在,并且给手机端返回如下结果:
字符串 | 代表含义 |
"0" | 账号密码不在数据库中 |
"1" | 账号密码正确 |
"404" | 服务器端连接不到数据库 |
4.手机端收到返回,根据返回的字符串进行不同的提示。
预备知识(建议有看不懂的再回来点相应的链接进去学习) POST常用设置
方法 | 描述 |
---|---|
SetRequestMethod(String) | 设置连接方式 |
urlCon.setDoInput(true) | 设置输入是否允许 |
urlCon.setDoOutput(true) | 设置输出是否允许 |
setRequestProperty(String,String) | 配置请求属性 |
关于Http的知识
【php + MySQL + Android】一个超简单的Http实践_勇敢di牛牛的博客-CSDN博客一个超简单的Android Http实践。https://blog.csdn.net/niuguobao/article/details/124307587?spm=1001.2014.3001.5502
登录界面UI的代码【php + MySQL + Android】Android登陆界面设计(1)_勇敢di牛牛的博客-CSDN博客做一个简单的登陆界面。https://blog.csdn.net/niuguobao/article/details/124299640?spm=1001.2014.3001.5502
关于php的知识,以及对Mysql的 *** 作【php + MySQL + Android】php对数据库进行 *** 作(1)_勇敢di牛牛的博客-CSDN博客php语言对数据库进行 *** 作。https://blog.csdn.net/niuguobao/article/details/124248858?spm=1001.2014.3001.5502
重难知识点整理: Json🚀Json是什么?Toast答:JavaScript Object Natation, 一种轻量级的数据交换格式, 与XML一样,
🚀Android中创建json并且添加内容:
广泛被采用的客户端和服务端交互的解决方案!具有良好的可读和便于快速编写的特性🚀服务器中收到的json字符串JSONObject json = new JSONObject(); json.put("username",username); json.put("password",password);
🚀🚀🚀服务器的php文件对收到json解析(重点中的重点){ "username":"yongganniuniu","password":"123456" }
$res = file_get_contents("php://input");//接受参数post $josn = json_decode($res, true); //解析 $password = $josn["password"]; //提取账号密码 $username = $josn["username"];
🚀Tost实现:Http获取返回有延时Toast.makeText()各个参数都是干嘛的Toast toast = Toast.makeText(MainActivity.this, tip,Toast.LENGTH_SHORT); toast.show(); //只有调用了show方法才会显示
Toast:是一个类,主要管理消息的提示。
makeText(),是Toast的一个方法,用来显示信息,分别有三个参数。
🚒第一个参数:是上下文参数,指当前页面显示
🚒第二个参数:是你想要显示的内容。
🚒第三个参数:Toast.LENGTH_LONG是你指你提示消息,显示的时间,这个是稍微长点
对应的另一个是ToastLENGTH_SHORT,这个时间短点儿,大概2秒钟。
执行post请求需要时间,我们的执行是异步多线程,不能在发送post请求后立马做出判断,要等消息返回在执行相关 *** 作。
Android代码package com.example.testapp;
import android.annotation.SuppressLint;
import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Looper;
import android.os.Message;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import org.json.JSONException;
import org.json.JSONObject;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
public class MainActivity extends Activity {
Button btn_login;
Button btn_register;
EditText edt_user;
EditText edt_password;
//private Handler handler;
private String res;
private static final int SUCCESS = 0;
private static final int FAILURE = 1; //
private String password= "";
private String username ="";
String stringUrl = "http://nnggb.com/test/test.php";
private Handler mHander = new Handler(Looper.getMainLooper()) {
@SuppressLint("SetTextI18n")
public void handleMessage(Message msg) {
switch(msg.what){
case SUCCESS:
ShowLoginToast(); //提示账号密码是否正确以及服务器是否出现问题
break;
case FAILURE:
Toast toast = Toast.makeText(MainActivity.this,"请求失败,请检查网络",Toast.LENGTH_SHORT);
toast.show();
break;
}
}
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
btn_login = findViewById(R.id.bt_login);
btn_register = findViewById(R.id.bt_register);
edt_user = findViewById(R.id.edt_user);
edt_password =findViewById(R.id.edt_password);
btn_login.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
username = String.valueOf(edt_user.getText()); //获取文本框内容
password = String.valueOf(edt_password.getText());
GetURLResByPost();
//ShowLoginToast(); //千万不能写在这里,这里网络请求还没回来,res是空的
}
});
}
public void GetURLResByPost(){
new Thread(new Runnable(){
public void run(){
try {
JSONObject json = new JSONObject();
json.put("username",username);
json.put("password",password);
Log.i("勇敢id牛牛", String.valueOf(json));
URL myurl = new URL(stringUrl);
HttpURLConnection urlCon = (HttpURLConnection)myurl.openConnection();
urlCon.setConnectTimeout(3000);
urlCon.setDoInput(true); //设置允许输入
urlCon.setDoOutput(true);//设置输出允许
urlCon.setRequestMethod("POST");
OutputStreamWriter out = new OutputStreamWriter(urlCon.getOutputStream());
//DataOutputStream out = new DataOutputStream(urlCon.getOutputStream());
out.write(json.toString());
out.flush();
out.close();
if(urlCon.getResponseCode() == 200){
InputStreamReader in = new InputStreamReader(urlCon.getInputStream());
BufferedReader buffer = new BufferedReader(in);
// String inputLine = null;
// StringBuffer pageBuffer = new StringBuffer();
// while((inputLine = buffer.readLine()) != null){
// pageBuffer.append(inputLine +"\n");
// } //上面的写法是接受的数据有多行,我这里只有一个数字。用着个方法会多一个空格。
//res = String.valueOf(buffer.read()); //这种写法是错误的
res = buffer.readLine(); //只读取第一行
mHander.sendEmptyMessage(0);
in.close();
buffer.close();
urlCon.disconnect();
}else{
mHander.sendEmptyMessage(1);
}
} catch (MalformedURLException e) {
e.printStackTrace();
mHander.sendEmptyMessage(1);
} catch (IOException e) {
mHander.sendEmptyMessage(1);
e.printStackTrace();
} catch (JSONException e) {
e.printStackTrace();
}
}
}).start();
}
public void ShowLoginToast(){
String tip = "";
if (res.equals("0")){ //查询的密码不正确
tip = "账号或密码不正确";
}else if(res.equals("1")){
tip = "登录成功 ";
}else if(res.equals("404")){
tip = "服务器端配置错误";
}
if (!tip.equals("")){
Toast toast = Toast.makeText(MainActivity.this, tip,Toast.LENGTH_SHORT);
toast.show();
}
}
}
PHP代码
" .username ."
". password ."
" .dbname ;
// 创建连接
extract($_POST);
$res = file_get_contents("php://input");
$josn = json_decode($res, true);
$password = $josn["password"];
$username = $josn["username"];
$conn = new mysqli(servername, username, password, dbname);
// 检测连接
if ($conn->connect_error) {
echo "404";
//die("连接失败: " . $conn->connect_error);
}
$sql="SELECT `username` FROM `test` WHERE `username`= '$username' AND `email` = '$password' ";
$res = $conn->query($sql);
if ($res->num_rows > 0) {
// 输出数据
//$row= mysqli_fetch_assoc($res);
echo "1";
}else{
echo "0";
//$_SESSION['username'] = "xxx";
}
?>
🚀看完了还有疑问请私信我,或者评论区留言。
🚀发现错误或者有建议,请评论区留言或私信。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)