/**
* api接口
*/
interfaceApiService {
????//上傳頭像
? ??@Multipart
????@POST(Constant.MEMBER_URL)
????Observable<Object>upLoadImage(@Query("userId") String userId,@PartMultipartBody.Part file,@QueryMap Map<String,String> map);
}
需要注意的,我已經用黑色加粗字體顯示,@Multipart 是 Retrofit 用于文件上傳的注解,配合@POST一起使用;
和平時的使用 Retrofit 網絡請求不一樣的是,上傳圖片需要添加請求頭,一般都是在用戶信息頁上傳頭像,就以用戶信息的一般邏輯舉例;
@Query("userId") String userId,這些是你的普通參數,什么用戶名,密碼,年齡,前端和服務器約定的是什么字段參數,就寫在@Query里,用引號括起來,有多少寫多少;
@QueryMap Map<String ,String> map,是前端和服務器約定好的方法 act? mod;
@PartMultipartBody.Part file? ,是你要上傳到服務器的圖片參數;

RequestBody requestFile = RequestBody.create(MediaType.parse("multipart/form-data"),file);
MultipartBody.Part body = MultipartBody.Part.createFormData("imageFile",file.getName(),requestFile);
multipart/form-data? 就是決定上傳頭像是否成功的關鍵所在------請求頭;
imageFile 是前端和服務器約定好的這個圖片的參數名,其實和 userId , password , age等等都是同級別的參數,只不過要放在這里添加,因為是給這個 imageFile 添加請求頭,當然 你那里有可能叫做 picture? ,叫 image ,總之是什么,你就放什么;
每一步缺一不可;