以請求 https://api.github.com/rate_limit 這個 API 為例。
因為這 API 並沒有提供 POST 方式的請求,這裡僅是示範如何帶入參數並使用。
AndroidManifest.xml
<uses-permission android:name="android.permission.INTERNET" />
MainActivity.java
public class MainActivity extends Activity {
public interface ApiUri {
// @Multipart 設定請求使用 Multipart 方式
// @Part 設定 Multipart 的參數名稱和值,並指定使用 RequestBody 類型。
@Multipart
@POST("/rate_limit")
Call<ResponseBody> get(@Part("photo") RequestBody photo);
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
RequestBody requestBody = null;
try {
// 讀取圖片檔案所有的二進位數值,正常的情境應是讀取檔案,這裡為求快速執行所以任選一張 Android 內建的圖片。
// Android Studio 預期 openRawResource() 方法會讀取 R.raw 的資源,這裡加上 + 號我猜測是繞過檢查機制,避免錯誤訊息。
InputStream in = getResources().openRawResource(+android.R.drawable.sym_def_app_icon);
byte[] bytePhoto = new byte[in.available()];
in.read(bytePhoto);
// 建立 MultipartRequestBody,其內包含要上傳的圖片資料。
requestBody = RequestBody.create(MediaType.parse("application/octet-stream"), bytePhoto);
} catch (IOException e) {
e.printStackTrace();
}
Retrofit retrofit = new Retrofit.Builder()
.baseUrl("https://api.github.com")
.build();
ApiUri apiUri = retrofit.create(ApiUri.class);
Call<ResponseBody> call = apiUri.get(requestBody);
call.enqueue(new Callback<ResponseBody>() {
@Override
public void onResponse(Call<ResponseBody> call, Response<ResponseBody> response) {
// 因為此 API 僅使用 GET,不提供 POST 方法,所以會取得 404 狀態碼。
int result = response.code();
Log.d("MainActivity", result + "");
}
@Override
public void onFailure(Call<ResponseBody> call, Throwable t) {
t.printStackTrace();
}
});
}
}