安卓okhttp3進行網路請求,一個簡單的登入頁面的實現
文章目錄
一、前言
寫在文章的前面:為了不浪費大家的時間,本文只是為了記錄一下自己開發過程中遇到的問題,而且這只是一個最簡單的登入頁面的實
現,不能解決安卓大佬開發上的任何問題,只是給我自己或者和我一樣的0基礎的人看的。
本文通過okhttp3實現安卓app進行後臺webapi的網路訪問。
初學android,想開發一個簡單的app,在網上查閱了大量的資料,但是都是一些很老的教程了,雖然適用,但是講的不是很清楚,對
沒有系統學習過安卓的人來說很不友好。
二、配置okhttp3
<!--在app目錄下的 build.gradle檔案中新增 -->
dependencies {
implementation("com.squareup.okhttp3:okhttp:4.1.0")
}
<!-- AndroidManifest.xml檔案中新增 -->
<!--開啟網路許可權,不然不能進行網路訪問-->
<uses-permission android:name="android.permission.INTERNET" />
三、activity_main.xml檔案
因為是登入介面,並且只作為示範,所以樣式簡陋,將就著能用就好。
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<EditText
android:id="@+id/edit_username"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginStart="160dp"
android:layout_marginLeft="160dp"
android:layout_marginTop="116dp"
android:layout_marginEnd="38dp"
android:layout_marginRight="38dp"
android:ems="10"
android:hint="@string/edit_message"
android:inputType="textPersonName"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.688"
app:layout_constraintStart_toEndOf="@+id/textView2"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<TextView
android:id="@+id/textView2"
android:layout_width="0dp"
android:layout_height="46dp"
android:layout_marginStart="39dp"
android:layout_marginLeft="39dp"
android:layout_marginEnd="9dp"
android:layout_marginRight="9dp"
android:gravity="center"
android:text="@string/edit_username_title"
app:layout_constraintBaseline_toBaselineOf="@+id/edit_username"
app:layout_constraintEnd_toStartOf="@+id/edit_username"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintStart_toStartOf="parent" />
<TextView
android:id="@+id/textView3"
android:layout_width="138dp"
android:layout_height="152dp"
android:layout_marginStart="39dp"
android:layout_marginLeft="39dp"
android:layout_marginEnd="10dp"
android:layout_marginRight="10dp"
android:gravity="center"
android:text="@string/edit_password_title"
app:layout_constraintBaseline_toBaselineOf="@+id/edit_password"
app:layout_constraintEnd_toStartOf="@+id/edit_password"
app:layout_constraintStart_toStartOf="parent" />
<EditText
android:id="@+id/edit_password"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="24dp"
android:layout_marginEnd="37dp"
android:layout_marginRight="37dp"
android:ems="10"
android:hint="@string/edit_message_password"
android:inputType="textPassword"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toEndOf="@+id/textView3"
app:layout_constraintTop_toBottomOf="@+id/edit_username" />
<Button
android:id="@+id/btn_login"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="84dp"
android:onClick="login"
android:text="@string/button_send"
app:layout_constraintStart_toEndOf="@+id/textView3"
app:layout_constraintTop_toBottomOf="@+id/edit_password" />
</androidx.constraintlayout.widget.ConstraintLayout>
四、MainActivity的實現
import androidx.appcompat.app.AppCompatActivity;
import android.content.Intent;
import android.os.Bundle;
import android.util.JsonToken;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.FrameLayout;
import android.widget.Toast;
import org.json.JSONArray;
import okhttp3.FormBody;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;
public class MainActivity extends AppCompatActivity {
public static final String EXTRA_MESSAGE ="com.example.myapplication.MESSAGE";
public EditText edit_username;
public EditText edit_password;
public Button btn_login;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
public void login(View view){
btn_login = (Button)findViewById(R.id.btn_login);
btn_login.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
new Thread(new Runnable() {
@Override
public void run() {
try{
edit_username = (EditText) findViewById(R.id.edit_username);
edit_password = (EditText) findViewById(R.id.edit_password);
String username = edit_username.getText().toString();
String password = edit_password.getText().toString();
Log.d("賬號" ,username);
Log.d("密碼" ,password);
FormBody.Builder params = new FormBody.Builder();
params.add("username",username);
params.add("password",password);
Log.d("引數",params+"");
OkHttpClient client = new OkHttpClient();
Request request = new Request.Builder()
.url("http://127.0.0.1:8081/user/login")
.post(params.build())
.build();
Log.d("URL",request+"");
Response response = client.newCall(request).execute();
String responseData = response.body().string();
Intent intent = new Intent(MainActivity.this,SecondActivity.class);
startActivity(intent);
Log.d("輸出結果:",responseData);
}catch (Exception e){
e.printStackTrace();
runOnUiThread(new Runnable() {
@Override
public void run() {
Toast.makeText(MainActivity.this,"網路連線失敗!",Toast.LENGTH_SHORT).show();
}
});
}
}
}).start();
}
});
}
}
五、SecondActivity實現
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_second);
}
六、activity_second.xml
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".SecondActivity">
<TextView
android:id="@+id/textView5"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="214dp"
android:text="看到這個說明登入成功"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
七、登入頁面
寫在文章末,雖然是一個很簡單的demo,來源也都是網上資源的整合,不過也算是記錄一下自己開發的第一個頁面了,後面可能會一步
步的跟進我專案的開展,繼續寫一些學習過程中遇到的問題。僅作為記錄生活使用。本程式碼複製即可執行,如果能幫到您,萬分榮幸。