編輯:關於Android編程
幾個月前寫過一篇博客《xUtils3.0框架學習筆記》 ,上面也有記錄通過xUtils實現文件上傳的使用方法,代碼如下:
private void upLoadOnClick(View v) {
String upUrl = "/mnt/sdcard/pic/test.jpg";//指定要上傳的文件
final ProgressDialog dia = new ProgressDialog(this);
dia.setMessage("加載中....");
dia.show();
RequestParams params = new RequestParams(upUrl);
params.addBodyParameter("file", new File(upUrl));
x.http().post(params, new Callback.CommonCallback<String>() {
@Override
public void onSuccess(String result) {
//加載成功回調,返回獲取到的數據
Log.i(TAG, "onSuccess: " + result);
}
@Override
public void onFinished() {
dia.dismiss();//加載完成
}
@Override
public void onCancelled(CancelledException cex) {
}
@Override
public void onError(Throwable ex, boolean isOnCallback) {
}
});
}
我在項目中通過以上方法進行圖片上傳,發現有點小問題,或許是我把這個方法使 用不到位。
在與服務器聯調時,同事總是告訴我沒有收到文件流數據,結果肯定是上傳失敗。後來繼續看代碼跟進,發現通過
` params.addBodyParameter("file", new File(upUrl));`
這種方式傳遞文件數據,默認的請求數據類型並不是文件類型所需要的multipart/form-data類型數據。
通過看相應源碼,我們在使用xUtils實現網絡請求時,通過
`RequestParams params = new RequestParams(Constants.ADD_ZONE_PLANE);`創建請求,然後通過
` params.setRequestBody(body);`傳遞請求參數。
其實setRequestBody(RequestBody requestBody)方法是調用RequestParams的父類BaseParams中的方法:
public void setRequestBody(RequestBody requestBody) {
this.requestBody = requestBody;
}
考慮是參數數據類型問題,我們就從傳遞參數RequestBody入手,發現在xUtils中,默認有:
FileBody,InputStreamBody,MultipartBody及StringBody等幾種類型的請求Body,當然這些都是RequestBody的子類 。
發現MultipartBody類型中,有這個方法:
private void generateContentType() {
String boundaryPostfix = Double.toHexString(Math.random() * 0xFFFF);
boundaryPostfixBytes = boundaryPostfix.getBytes();
contentType = "multipart/form-data; boundary=" + new String(BOUNDARY_PREFIX_BYTES) + boundaryPostfix;
}
看到返回的類型是multipart/form-data...,正是我想要的,所以請求參數就從MultipartBody入手考慮上傳文件。
MultipartBody類的構造方法如下:
//參數分別是要傳入的數據,和數據編碼類型
public MultipartBody(List<KeyValue> multipartParams, String charset) {
if (!TextUtils.isEmpty(charset)) {
this.charset = charset;
}
this.multipartParams = multipartParams;
generateContentType();
...
}
從構造方法需要的參數開始,我們一步一步地實現MultipartBody所需要的數據。
//創建List<KeyValue>對象
List<KeyValue> list = new ArrayList<>();
//給list中添加數據,filePah是上傳的文件路徑,比如sd卡中圖片
list.add(new KeyValue("file", new File(filePah)));//文件流數據
//其它參數,根據項目而定,比如我的項目中要傳入的參數是json格式的
list.add(new KeyValue("parameters", json.toString()));
//創建MultipartBody
MultipartBody body = new MultipartBody(list, "UTF-8");
//添加請求參數
params.setRequestBody(body);
這樣就可以實現文件上傳,最後貼下整個請求方法的相關代碼:
//要傳遞給服務器的json格式參數
JSONObject json = new JSONObject();
try {
json.put("devId", id);
json.put("devName", devName);
json.put("keyWord", keyWord);
} catch (JSONException e) {
e.printStackTrace();
}
//構建RequestParams對象,傳入請求的服務器地址URL
RequestParams params = new RequestParams(Constants.UPLOAD_FILE);
params.setAsJsonContent(true);
List<KeyValue> list = new ArrayList<>();
list.add(new KeyValue("file", new File(filePah)));
list.add(new KeyValue("parameters", json.toString()));
MultipartBody body = new MultipartBody(list, "UTF-8");
params.setRequestBody(body);
x.http().post(params, new org.xutils.common.Callback.CommonCallback<String>() {
@Override
public void onSuccess(String result) {
LogUtil.e("請求結果:" + result);
}
@Override
public void onFinished() {
//上傳完成
}
@Override
public void onCancelled(CancelledException cex) {
//取消上傳
}
@Override
public void onError(Throwable ex, boolean isOnCallback) {
//上傳失敗
LogUtil.e("請求失敗:" + ex.toString());
}
});
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持本站。
Android開發之自定義CheckBox
要實現的效果如下考慮到關鍵是動畫效果,所以直接繼承View。不過CheckBox的超類CompoundButton實現了Checkable接口,這一點值得借鑒。下面記錄一
Android 服務(service)的生命周期以及利用bindservice調用服務裡面的方法
服務的生命周期 服務的生命周期跟啟動服務的方法有關: 當采用Context.startService()方法啟動服務,與之有關的生命周期方法 onCreate()
Android中創建對話框(確定取消對話框、單選對話框、多選對話框)實例代碼
Android中可以創建三種對話框、確定取消對話框、單選對話框、多選對話框android中的確定取消對話框演示示例Android中使用單選對話框的演示案例android中
Android實現透明度可變的標題欄效果
我們在做類似於個人主頁類應用的時候,可能會遇到這樣的需求,效果如下相信大家應該看明白是什麼效果了,就是隨著列表的滑動,上面的標題欄的透明度會隨之變化。在IOS中,有很多的