Android端使用retrofit上傳多張圖片,後端使用Php接收圖片(包含前後端代碼)

來源:互聯網
上載者:User
1.先列出Android端使用的library:

dependencies {    ...    compile 'com.jakewharton:butterknife:7.0.1'    compile 'com.squareup:otto:1.3.5'    compile 'cn.finalteam:galleryfinal:1.4.8.4'    compile 'com.squareup.retrofit:retrofit:1.9.0'    compile 'com.squareup.okhttp:okhttp-urlconnection:2.0.0'    compile 'com.squareup.okhttp:okhttp:2.0.0'    compile 'com.github.bumptech.glide:glide:3.6.1'    compile 'com.jcodecraeer:xrecyclerview:1.2.6'    compile 'com.baoyz.actionsheet:library:1.1.5'    compile 'com.nostra13.universalimageloader:universal-image-loader:1.9.5'    compile 'io.reactivex:rxjava:1.0.6'    compile 'io.reactivex:rxandroid:0.23.0'    compile files('libs/fastjson-1.2.7.jar')}

Android端代碼:

public interface ApiService {//  上傳一個檔案/圖片    @Multipart    @POST("/UploadFileDemo/android_upload_file/upload.php")    Observable uploadFile(@Part("uploadfile") TypedFile file);//  上傳多張圖片    @POST("/UploadFileDemo/android_upload_file/uploads.php")    Observable uploadFiles(@Body MultipartTypedOutput multipartTypedOutput);}
public class Client {    public static String API_URL = Constant.API_URL;    public static ExecutorService mExecutorService;    private static ApiService instance;    public static ApiService getServiceClient() {        if (instance == null) {            synchronized (Client.class) {                if (instance == null) {                    OkHttpClient okHttpClient = new OkHttpClient();                    okHttpClient.setCookieHandler(new MyCookieManager());                    okHttpClient.setReadTimeout(100, TimeUnit.SECONDS);                    okHttpClient.setConnectTimeout(100, TimeUnit.SECONDS);                    RestAdapter.Builder restAdapter = new RestAdapter.Builder();                    restAdapter.setRequestInterceptor(new ApiHeaders());                    restAdapter.setEndpoint(API_URL);                    restAdapter.setClient(new OkClient(okHttpClient));                    restAdapter.setLogLevel(RestAdapter.LogLevel.FULL);                    mExecutorService = Executors.newCachedThreadPool();                    instance = restAdapter.build().create(ApiService.class);                }            }        }        return instance;    }    public static void stopAll() {        List pendingAndOngoing = mExecutorService.shutdownNow();    }    static class MyCookieManager extends CookieManager {        @Override        public void put(URI uri, Map> stringListMap) throws IOException {            super.put(uri, stringListMap);            if (stringListMap != null && stringListMap.get("Set-Cookie") != null)                for (String string : stringListMap.get("Set-Cookie")) {                    String cookieValue = string.substring(0, string.indexOf("\"; ") + 1);                    if (string.contains("A2=\"")) {                        //儲存到應用                    }                    if (string.contains("PB3_SESSION=\"")) {                        ////儲存到應用                    }                }        }    }    static class ApiHeaders implements RequestInterceptor {        @Override        public void intercept(RequestFacade request) {            request.addHeader("User-Agent", "Mozilla/5.0 (Linux; U; Android 4.1.1; zh-cn; HTC One X - 4.1.1 - API 16 - 720x1280 Build/JRO03S) AppleWebKit/534.30 (KHTML, like Gecko) Version/4.0 Mobile Safari/534.30");            request.addHeader("Accept", "*/*");            request.addHeader("Accept-Language", "zh-cn,zh");        }    }}

上傳關鍵代碼:

//使用MultipartTypedOutput類來上傳多張圖片 public void uploadFiles(List paths) {        MultipartTypedOutput multipartTypedOutput = new MultipartTypedOutput();        for (String imgPath : paths){        //注意“uploadfile[]”一定要帶“[]”,表明上傳的是數組,也就是多張圖片,不能寫“uploadfile”            multipartTypedOutput.addPart("uploadfile[]", new TypedFile("", new File(imgPath)));        }        mApi.uploadFiles(multipartTypedOutput)                .subscribeOn(Schedulers.computation())                .subscribe(response -> handleUploadFile(response), error -> handleFailure(error));    } private void handleUploadFile(Response response) {    System.out.println(response.getUrl());    try {        InputStream in = response.getBody().in();        String responseString = inputStream2String(in);        Log.i("AAA", responseString);        //解析json資料        //otto事件傳遞        mBus.post(responseString);    } catch (IOException e) {        e.printStackTrace();    }}//接收事件代碼 @Subscribe //需要註解@Subscribe ,表明在這個函數接收資料public void uploadFileResponse(String response) {    Message msg = JSON.parseObject(response, Message.class);    List imgUrls = msg.getImgUrls();    if (msg.getCode() == 1) {        if (choosePhotoListAdapter == null) {            choosePhotoListAdapter = new ChoosePhotoListAdapter(this, null, imgUrls);            lvPhotoShow.setAdapter(choosePhotoListAdapter);        }        choosePhotoListAdapter.notifyDataSetChanged();    }}

Php端代碼:

//初學php,寫的比較簡單,不太健壯,像圖片是否已經上傳過,都沒有判斷,大家自己補充啊^_^ $error) {    if ($error == UPLOAD_ERR_OK) {        $tmp_name = $_FILES["uploadfile"]["tmp_name"][$key];        $name = $_FILES["uploadfile"]["name"][$key];        $uploadfile = $base_path . $name;        $isSave = move_uploaded_file($tmp_name, $uploadfile);        if ($isSave){            $imgs[]=$uploadfile;        }    }}if ($isSave) {    $array = array("code" => "1", "message" =>"上傳圖片成功"    , "imgUrls" => $imgs);    echo json_encode($array);} else {    $array = array("code" => "0", "message" => "上傳圖片失敗," . $_FILES ['uploadfile'] ['error']    , "imgUrls" => $imgs);    echo json_encode($array);}

其實上傳成功的關鍵是part需要帶uploadfile[] ,【 multipartTypedOutput.addPart("uploadfile[]", new TypedFile("", new File(imgPath)));】我在這個地方失敗了幾十次,無意中看見html網頁批量上傳的name屬性中帶了[],我就試了試,果然成功了。

代碼資源下載

Paste_Image.png

Paste_Image.png

超級簡單的Android Studio jni 實現(無需命令列)

  • 相關文章

    聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.