Devahoy Logo
PublishedAt

Android

Day 7 - Android AsyncHttp

Day 7 - Android AsyncHttp

สวัสดีครับ บทความนี้เป็นบทความที่ 7 แล้วนะครับ ที่ผมจะมาเขียน ในซีรีย์ Learn 30 Android Libraries in 30 days

สำหรับบทความทั้งหมด อ่านได้จากด้านล่างครับ

สำหรับวันนี้ขอนำเสนอเรื่อง Android Async Http ครับ สำหรับใครที่เคยติดตามอ่านบล็อกผมเก่าๆ อาจจะพบว่าผมเคยนำมาใช้แล้ว แต่ว่ายังไม่เคยพูดถึง รายละเอียดเท่าไหร่ วันนี้เลยถือโอกาส Overview มาให้ละกันครับ

Android Async Http คืออะไร?

Android Async Http เป็น Asynchronous Callback Http เพื่อแก้ไขปัญหา OnMainThreadException เนื่องจาก Library ตัวนี้ มันทำงานนอก Main UI Thread ครับ การใช้งานก็ง่าย มี Callback กลับมา มี response code กลับมา ว่า error หรือ success สำหรับใครที่ไม่อยากใช้ AsyncTask เวลาคอนเนค Http ก็มาลองใช้ตัวนี้ได้

Features

  • Asynchronous Http Requrest และ Callback
  • การทำงาน ทำงานนอก UI Thread ทำให้ไม่มีปัญหา OnMainThreadException
  • รองรับ GET/POST ผ่าน RequestParam
  • รองรับ Multipart File
  • รองรับ JSON
  • อื่นๆ อีกเพียบ อ่านได้จาก Documentation

Installaton

ในส่วนขั้นตอนการติดตั้ง หากใครใช้แบบ jar ก็โหลดไฟล์ได้ที่นี่ andriod-async-http-1.4.5.jar แล้วก็อปไปไว้ที่โฟลเดอร์ libs/ ในโปรเจ็ค จากนั้นเปิดไฟล์ build.gradle

1
dependencies {
2
compile fileTree(dir: 'libs', include: ['*.jar'])
3
}

แล้ว Sync Project

หรือหากใครต้องการใช้มันโหลดมาจาก Maven Central เลย ก็แค่เพิ่มนี้ลงไปใน build.gradle

1
dependencies {
2
compile 'com.loopj.android:android-async-http:1.4.5'
3
}

กด Sync Project

หากใครมี error ว่าหาไฟล์ library จาก mavenCentral ไม่เจอ สาเหตุก็เพราะว่า Android Studio เปลี่ยนไปใช้ jCenter() สำหรับ search หา repository แทน mavenCentral() แล้ว ฉะนั้นก็ต้องเพิ่ม ส่วนนี้ลงไปที่ไฟล์ build.gradle ของ Root Project คนละไฟล์กับด้านบนนะ!

1
// Top-level build file where you can add configuration options common to all sub-projects/modules.
2
buildscript {
3
...
4
}
5
6
allprojects {
7
repositories {
8
jcenter()
9
maven {
10
url 'http://repo1.maven.org/maven2/'
11
}
12
}
13
}

Getting Started

สำหรับการใช้งานเจ้า Android Async Http นั้น ใน Document มีตัวอย่างให้ดูแล้วครับ แถมมี Sample Code ให้ดูอีก สำหรับใครที่ยังไม่มีพื้นฐาน แนะนำให้อ่าน Document และ Sample Code ประกอบนะครับ

GET

การ get นั้นทำได้ง่ายมากๆ ด้วยโค๊ดนี้

1
String URL = "https://devahoy.com";
2
AsyncHttpClient client = new AsyncHttpClient();
3
client.get(URL, new AsyncHttpResponseHandler() {
4
@Override
5
public void onSuccess(int statusCode, Header[] headers, byte[] responseBody) {
6
7
}
8
9
@Override
10
public void onFailure(int statusCode, Header[] headers, byte[] responseBody, Throwable error) {
11
12
}
13
});

มาลองทำโปรเจ็คเล่นๆดูครับ ผมใช้ 2 ไฟล์คือ AndroidAsyncActivity.java และไฟล์เลเอาท์ชื่อ activity_async.xml เอาไว้สำหรบแสดงผลลัพธ์กลับมาครับ ถ้าใช้ Toast มันจะมองไม่ทัน

เริ่มแรก ทีไฟล์เลเอาท์เป็นแบบนี้

1
<?xml version="1.0" encoding="utf-8"?>
2
3
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
4
android:layout_width="match_parent"
5
android:layout_height="match_parent"
6
android:padding="16dp"
7
android:orientation="vertical">
8
9
<ScrollView
10
android:layout_width="match_parent"
11
android:layout_height="match_parent">
12
13
<TextView
14
android:id="@+id/text"
15
android:layout_width="match_parent"
16
android:layout_height="match_parent"
17
android:singleLine="false"/>
18
19
</ScrollView>
20
21
22
</LinearLayout>

คือเอาไว้แสดงผลลัพธ์เฉยๆ ไม่มีอะไรมาก

ส่วนที่ไฟล์จาวา ผมก็ใส่ดังนี้

1
package com.devahoy.learn30androidlibraries.day7;
2
3
import android.os.Bundle;
4
import android.support.v7.app.ActionBarActivity;
5
import android.widget.TextView;
6
7
import com.devahoy.learn30androidlibraries.R;
8
import com.loopj.android.http.AsyncHttpClient;
9
import com.loopj.android.http.AsyncHttpResponseHandler;
10
11
import org.apache.http.Header;
12
13
public class AndroidAsyncActivity extends ActionBarActivity {
14
15
private TextView mText;
16
private final String URL =
17
"http://web-60388f0d-d0d6-4b9a-bcf8-61d0507ea2b9.runnable.com";
18
19
@Override
20
protected void onCreate(Bundle savedInstanceState) {
21
super.onCreate(savedInstanceState);
22
setContentView(R.layout.day7_activity_async);
23
24
mText = (TextView) findViewById(R.id.text);
25
26
AsyncHttpClient client = new AsyncHttpClient();
27
client.get(URL + "/api/players", new AsyncHttpResponseHandler() {
28
@Override
29
public void onSuccess(int statusCode, Header[] headers, byte[] responseBody) {
30
if (statusCode == 200) {
31
mText.setText(new String(responseBody));
32
}
33
}
34
35
@Override
36
public void onFailure(int statusCode, Header[] headers, byte[] responseBody, Throwable error) {
37
38
}
39
});
40
41
}
42
}

ด้านบนในส่วน URL ต้องไปเปลี่ยนค่าเอาเองนะครับ ตัวอย่าง ผมลองทำ REST API เอาไว้แบบ sample นะครับ ตอนนั้นทำไว้เล่นๆ เอามาใช้ซะเลย โดยรันไว้ที่เว็บ Runnable เผื่อส่งค่า JSON กลับมา ดูรายละเอียดได้จากนี่้ RESTFul API with Node.js & Express 4 ให้กด Run จากนั้นค่อยเอา URL ในกรอบมาใส่

Copy Url

ทดสอบรันดู ก็ได้ดังรูป มีผลลัพธ์ตอบกลับมาแล้ว ผลลัพธ์เดียวกัน ถ้าเข้าหน้าเว็บด้วย http://web-60388f0d-d0d6-4b9a-bcf8-61d0507ea2b9.runnable.com/api/players (ส่วนนี้มันถูก gen ทุกครั้งที่ run อาจจะได้ url ไม่เหมือนกันนะครับ)

OnMobile

จากหน้าเว็บ

OnWeb

ข้อมูลด้านบนไม่อัพเดทนะครับ ปัจจุบัน ซัวเรส ย้ายไปบาร์เซโลน่าแล้ว ฮ่าๆ

ต่อมา ผมเห็นแล้วว่าส่งค่ามาเป็น JSON ฉะนั้นก็จะแมพ JSON เข้ากับ Model ที่กำลังสร้างเลย แบบนี้

ไฟล์ Player.java

1
package com.devahoy.learn30androidlibraries.day7;
2
3
public class Player {
4
5
private String id;
6
private String name;
7
private String club;
8
private String national;
9
private int age;
10
11
// GETTER and SETTER
12
// ...

ไฟล์ Players.java

1
package com.devahoy.learn30androidlibraries.day7;
2
3
import java.util.List;
4
5
public class Players {
6
private List<Player> players;
7
8
public List<Player> getPlayers() {
9
return players;
10
}
11
12
public void setPlayers(List<Player> players) {
13
this.players = players;
14
}
15
}

ผมใช้ Gson เข้ามาช่วยนิดนึง อ่านข้อมูล JSON ด้วย Gson บน Android ได้แบบนี้

1
package com.devahoy.learn30androidlibraries.day7;
2
3
import android.os.Bundle;
4
import android.support.v7.app.ActionBarActivity;
5
import android.widget.TextView;
6
7
import com.devahoy.learn30androidlibraries.R;
8
import com.google.gson.Gson;
9
import com.loopj.android.http.AsyncHttpClient;
10
import com.loopj.android.http.AsyncHttpResponseHandler;
11
12
import org.apache.http.Header;
13
14
public class AndroidAsyncActivity extends ActionBarActivity {
15
16
private TextView mText;
17
private final String URL =
18
"http://web-60388f0d-d0d6-4b9a-bcf8-61d0507ea2b9.runnable.com";
19
20
@Override
21
protected void onCreate(Bundle savedInstanceState) {
22
super.onCreate(savedInstanceState);
23
setContentView(R.layout.day7_activity_async);
24
25
mText = (TextView) findViewById(R.id.text);
26
27
final Gson gson = new Gson();
28
29
AsyncHttpClient client = new AsyncHttpClient();
30
client.get(URL + "/api/players", new AsyncHttpResponseHandler() {
31
@Override
32
public void onSuccess(int statusCode, Header[] headers, byte[] responseBody) {
33
if (statusCode == 200) {
34
// mText.setText(new String(responseBody));
35
StringBuilder result = new StringBuilder();
36
37
Players players = gson.fromJson(new String(responseBody),
38
Players.class);
39
40
for (Player player : players.getPlayers()) {
41
result.append("Name: " + player.getName() + "\n");
42
result.append("Age : " + player.getAge() + "\n");
43
result.append("Club : " + player.getClub() + "\n");
44
result.append("National : " + player.getNational() + "\n");
45
result.append("================\n");
46
}
47
48
mText.setText(result);
49
}
50
}
51
52
@Override
53
public void onFailure(int statusCode, Header[] headers, byte[] responseBody, Throwable error) {
54
55
}
56
});
57
58
}
59
}

จากตัวอย่างด้านบน ก็ทำการแมพ JSON กับคลาสที่ผมสร้างขึ้น จากนั้น ก็เอามาแสดงใน TextView ผลลัพธ์เป็นแบบนี้

Result

อันนี้ก็เป็นตัวอย่างแบบ Basic นะครับ จริงๆจะทำเป็น ListView แล้วเวลากดแต่ละ Player ก็ไปหน้ารายละเอียด แต่ว่า เว้นไว้ละกันครับ ไม่มีเวลาทำ + ขี้เกียจ :D

POST

ส่วนการ POST ก็ทำได้ไม่ยากเลย แค่ใช้ RequestParams แล้วก็เปลี่ยนเป็นเมธอด post ซะ แบบนี้

1
RequestParams params = new RequestParams();
2
params.put("name", "Marco Reus");
3
params.put("national", "Germany");
4
5
AsyncHttpClient client = new AsyncHttpClient();
6
client.post(URL, params, new AsyncHttpResponseHandler() {
7
@Override
8
public void onSuccess(int statusCode, Header[] headers, byte[] responseBody) {
9
// check statusCode and get responsebody
10
}
11
12
@Override
13
public void onFailure(int statusCode, Header[] headers, byte[] responseBody, Throwable error) {
14
// throw err.
15
}
16
});

แล้วก็ยังมีอีกหลายๆอย่างครับ ไม่ว่าจะเป็นการอัพโหลดไฟล์ การดาวน์โหลดไฟล์ สามารถศึกษาเพิ่มเติมได้จากเว็บต้นฉบับเลยครับ สำหรับบทความนี้ก็ขอแนะนำ วิธีการใ้ช้งานเบื้องต้น ในแบบฉบับ Overview แค่นี้ก่อนครับ ขอบคุณครับ

Authors
avatar

Chai Phonbopit

เป็น Web Dev ในบริษัทแห่งหนึ่ง ทำงานมา 10 ปีกว่าๆ ด้วยภาษาและเทคโนโลยี เช่น JavaScript, Node.js, React, Vue และปัจจุบันกำลังสนใจในเรื่องของ Blockchain และ Crypto กำลังหัดเรียนภาษา Rust

Related Posts