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<Response> uploadFile(@Part("uploadfile") TypedFile file);// 上传多张图片 @POST("/UploadFileDemo/android_upload_file/uploads.php") Observable<Response> 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<Runnable> pendingAndOngoing = mExecutorService.shutdownNow(); } static class MyCookieManager extends CookieManager { @Override public void put(URI uri, Map<String, List<String>> 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<String> 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<String> imgUrls = msg.getImgUrls(); if (msg.getCode() == 1) { if (choosePhotoListAdapter == null) { choosePhotoListAdapter = new ChoosePhotoListAdapter(this, null, imgUrls); lvPhotoShow.setAdapter(choosePhotoListAdapter); } choosePhotoListAdapter.notifyDataSetChanged(); }}
Php端代码:
//初学php,写的比较简单,不太健壮,像图片是否已经上传过,都没有判断,大家自己补充啊^_^<?php/** * Created by PhpStorm. * User: zhangyipeng * Date: 16/2/18 * Time: 下午3:48 */$base_path = "./upload_file/"; //接收文件目录$imgs = array(); //定义一个数组存放上传图片的路径$isSave = false;if (!file_exists($base_path)) { mkdir($base_path);}foreach ($_FILES["uploadfile"]["error"] as $key => $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 实现(无需命令行)

PHP在現代編程中仍然是一個強大且廣泛使用的工具,尤其在web開發領域。 1)PHP易用且與數據庫集成無縫,是許多開發者的首選。 2)它支持動態內容生成和麵向對象編程,適合快速創建和維護網站。 3)PHP的性能可以通過緩存和優化數據庫查詢來提升,其廣泛的社區和豐富生態系統使其在當今技術棧中仍具重要地位。

在PHP中,弱引用是通過WeakReference類實現的,不會阻止垃圾回收器回收對象。弱引用適用於緩存系統和事件監聽器等場景,需注意其不能保證對象存活,且垃圾回收可能延遲。

\_\_invoke方法允許對象像函數一樣被調用。 1.定義\_\_invoke方法使對象可被調用。 2.使用$obj(...)語法時,PHP會執行\_\_invoke方法。 3.適用於日誌記錄和計算器等場景,提高代碼靈活性和可讀性。

Fibers在PHP8.1中引入,提升了並發處理能力。 1)Fibers是一種輕量級的並發模型,類似於協程。 2)它們允許開發者手動控制任務的執行流,適合處理I/O密集型任務。 3)使用Fibers可以編寫更高效、響應性更強的代碼。

PHP社區提供了豐富的資源和支持,幫助開發者成長。 1)資源包括官方文檔、教程、博客和開源項目如Laravel和Symfony。 2)支持可以通過StackOverflow、Reddit和Slack頻道獲得。 3)開發動態可以通過關注RFC了解。 4)融入社區可以通過積極參與、貢獻代碼和學習分享來實現。

PHP和Python各有優勢,選擇應基於項目需求。 1.PHP適合web開發,語法簡單,執行效率高。 2.Python適用於數據科學和機器學習,語法簡潔,庫豐富。

PHP不是在消亡,而是在不斷適應和進化。 1)PHP從1994年起經歷多次版本迭代,適應新技術趨勢。 2)目前廣泛應用於電子商務、內容管理系統等領域。 3)PHP8引入JIT編譯器等功能,提升性能和現代化。 4)使用OPcache和遵循PSR-12標準可優化性能和代碼質量。

PHP的未來將通過適應新技術趨勢和引入創新特性來實現:1)適應云計算、容器化和微服務架構,支持Docker和Kubernetes;2)引入JIT編譯器和枚舉類型,提升性能和數據處理效率;3)持續優化性能和推廣最佳實踐。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SublimeText3 Linux新版
SublimeText3 Linux最新版

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

Atom編輯器mac版下載
最受歡迎的的開源編輯器

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。