android多文件上傳
『壹』 Android上大文件分片上傳 具體怎麼弄
正常情況下,一般都是在長傳完成後,在伺服器直接保存。
?
1
2
3
4
5
6
7
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
//保存文件
context.Request.Files[0].SaveAs(context.Server.MapPath("~/1/" + context.Request.Files[0].FileName));
context.Response.Write("Hello World");
}
最近項目中用網路開源的上傳組件webuploader,官方介紹webuploader支持分片上傳。具體webuploader的使用方法見官網http://fex..com/webuploader/。
?
1
2
3
4
5
6
7
8
9
10
11
12
var uploader = WebUploader.create({
auto: true,
swf:'/webuploader/Uploader.swf',
// 文件接收服務端。
server: '/Uploader.ashx',
// 內部根據當前運行是創建,可能是input元素,也可能是flash.
pick: '#filePicker',
chunked: true,//開啟分片上傳
threads: 1,//上傳並發數
//由於Http的無狀態特徵,在往伺服器發送數據過程傳遞一個進入當前頁面是生成的GUID作為標示
formData: {guid:"<%=Guid.NewGuid().ToString()%>"}
});
webuploader的分片上傳是把文件分成若干份,然後向你定義的文件接收端post數據,如果上傳的文件大於分片的尺寸,就會進行分片,然後會在post的數據中添加兩個form元素chunk和chunks,前者標示當前分片在上傳分片中的順序(從0開始),後者代表總分片數。
『貳』 天翼雲盤Android客戶端如何上傳文件
通過Android客戶端上傳文件:1)登錄客戶端後在雲盤右上角點擊+菜單按鈕;2)在文件選擇界面中可選擇不同的類型文件上傳,完成後,點擊「上傳」按鈕,文件即進入傳輸列表進行上傳。客服75為你解答。寬頻服務可自助排障,簡單易操作,另外可辦理工單查詢、ITV修障、寬頻申請及密碼服務,方便快捷,更多功能敬請關注中國電信貴州客服。
『叄』 手機是安卓Android手機,天翼雲存儲上傳文件怎麼操作
天翼雲存儲上傳文件具體操作如下:1、通過網頁版上傳文件:1)登錄天翼雲存儲,在頁面上方點擊「上傳文件」按鈕;2)在彈出的對話框選擇「添加文件」按鈕;3)在彈出文件框選擇文件,點擊「打開」按鈕即可上傳。2、通過PC客戶端上傳文件:登錄PC客戶端,把需要上傳的文件直接拖動到PC客戶端即可進行上傳。3、通過Android客戶端上傳文件:1)登錄Android客戶端,在主界面下方點擊「上傳」按鈕,2)在SD卡中選擇文件,點擊「確定」按鈕,文件即進入傳輸列表進行上傳。4、通過iPhone或iPad客戶端上傳文件跟Android客戶端方法基本一致,但iPhone、iPad沒有SD卡,需在「照片」或「視頻」中選擇文件上傳。「天翼雲存儲」是為有天翼雲存儲需求的天翼帳號用戶提供的安全、高速、大容量的在線存儲管理、備份及共享的服務,支持多終端的個人數據中心,包括了媒體自動篩選、文件在線瀏覽及播放、雲轉碼瀏覽及播放、通訊錄安全備份、同步備份二合一等功能。無固定有效期,業務提供方中國電信有終止本業務的權利。適用於有天翼雲存儲需求的天翼帳號用戶。貴州地區用戶關注中國電信貴州客服公眾號可微信繳費,一鍵查話費充值,流量、積分、賬單、詳單均可自助操作,方便快捷。客服233為你解答。
『肆』 雲存儲——通過Android客戶端如何上傳文件
(1)登錄Android客戶端,在主界面下方點擊「上傳」按鈕,(2)在SD卡中選擇文件,點擊「確定」按鈕,文件即進入傳輸列表進行上傳。了解更多服務優惠點擊下方的「官方網址」客服221為你解答。
『伍』 安卓手機如何將文件傳送到另一個手機
手機文件怎麼傳到電腦?現在很多事情我們都能通過手機完成,因此上面也保存了很多重要的數據,如通訊錄聯系人、照片、微信聊天記錄等等,那這些數據怎麼傳到電腦上呢?今天就針對這個問題,給大家分享幾招,希望能夠幫助到你喲!
方法一:使用iCloud備份數據
打開蘋果手機上的設置,然後輸入自己的Apple ID進入「iCloud」,接著下滑找到「iCloud雲備份」並將其按鈕開啟,這樣當設備接入電源、鎖定且接入Wi-Fi時,將自動備份設備中的照片圖庫、賬戶信息、文稿等數據。
友情提示:每個iCloud賬號只有5GB的免費存儲空間,超出需要每個月支付少量費用才能繼續備份喲。
方法二:用電腦端iTunes備份數據
這個方法也是比較簡單的,在個人電腦上操作,沒有存儲空間的限制,具體操作如下:
打開個人電腦,並運行iTuens軟體,然後利用數據線將iPhone連接至電腦,待iTunes識別我們的iPhone型號後,點擊右上角的小手機圖標進入「摘要」,接著點擊右下角的「立即備份」按鈕,等待進度條完成100%即可成功備份。
其實除了以上的備份方式,我們還可以藉助「果備份」這款專業的蘋果數據備份軟體,相比於以上的兩招,這個方法更為簡單,且能在線預覽和導出備份好的數據,可視化操作,讓備份更簡單。
我們只需在果備份官網下載軟體,運行後用數據線將手機連接至電腦,待軟體識別出我們的設備後,點擊「開始備份」即可等待整機備份。
備份完成後,我們可以選擇需要的數據項進行查看或導出,在這里小編以微信聊天記錄為例,在數據項列表中點擊「微信聊天記錄」進入備份詳情頁,勾選需要的部分,在右下角選擇需要的格式即可將微信聊天記錄導出。
蘋果手機備份?生活中我們難免會遇到數據丟失的情況,因此定期備份才是有效保護數據的做法,小夥伴們還在等什麼呢?抓緊試試看吧!
『陸』 Android圖片批量上傳的功能。(圖片比較大)
Android中上傳圖片或者下載圖片,使用最多的是xUtils和imageloader、glide,選用這兩種的哪一種框架都行,因為是批量和圖片大容易造成界面卡以及上傳速度慢,對圖片操作不當就容易造成OOM異常,一般對於批量上傳大圖片都需要對圖片也處理,然後在上傳第一步需要對圖片進行比例壓縮之後再進行質量壓縮,處理之後的圖片比之前的圖片會小很多,再加上框架的上傳處理,會有很好的效果,希望對你有所幫助
『柒』 android如何實現圖片批量上傳
首先,以下架構下的批量文件上傳可能會失敗或者不會成功:
1.android客戶端+springMVC服務端:服務端採用org.springframework.web.multipart.MultipartHttpServletRequest作為批量上傳接收類,這種搭配下的批量文件上傳會失敗,最終服務端只會接受到一個文件,即只會接受到第一個文件。可能因為MultipartHttpServletRequest對servlet原本的HttpServletRequest類進行封裝,導致批量上傳有問題。
2.android客戶端+strutsMVC服務端:
上傳成功的方案:
採用android客戶端+Servlet(HttpServletRequest)進行文件上傳。
Servlet端代碼如下:
[java] view plainprint?
DiskFileItemFactory factory = new DiskFileItemFactory();
ServletFileUpload upload = new ServletFileUpload(factory);
try
{
List items = upload.parseRequest(request);
Iterator itr = items.iterator();
while (itr.hasNext())
{
FileItem item = (FileItem) itr.next();
if (item.isFormField())
{
System.out.println("表單參數名:" + item.getFieldName() + ",表單參數值:" + item.getString("UTF-8"));
}
else
{
if (item.getName() != null && !item.getName().equals(""))
{
System.out.println("上傳文件的大小:" + item.getSize());
System.out.println("上傳文件的類型:" + item.getContentType());
// item.getName()返回上傳文件在客戶端的完整路徑名稱
System.out.println("上傳文件的名稱:" + item.getName());
File tempFile = new File(item.getName());
// 上傳文件的保存路徑
File file = new File(sc.getRealPath("/") + savePath, tempFile.getName());
item.write(file);
request.setAttribute("upload.message", "上傳文件成功!");
} else
{
request.setAttribute("upload.message", "沒有選擇上傳文件!");
}
}
}
}
catch (FileUploadException e)
{
e.printStackTrace();
}
catch (Exception e)
{
e.printStackTrace();
request.setAttribute("upload.message", "上傳文件失敗!");
}
request.getRequestDispatcher("/uploadResult.jsp").forward(request, response);
android端代碼如下:
[java] view plainprint?
public class SocketHttpRequester {
/**
*多文件上傳
* 直接通過HTTP協議提交數據到伺服器,實現如下面表單提交功能:
* <FORM METHOD=POST ACTION="http://192.168.1.101:8083/upload/servlet/UploadServlet" enctype="multipart/form-data">
<INPUT TYPE="text" NAME="name">
<INPUT TYPE="text" NAME="id">
<input type="file" name="imagefile"/>
<input type="file" name="zip"/>
</FORM>
* @param path 上傳路徑(註:避免使用localhost或127.0.0.1這樣的路徑測試,因為它會指向手機模擬器,你可以使用http://www.iteye.cn或http://192.168.1.101:8083這樣的路徑測試)
* @param params 請求參數 key為參數名,value為參數值
* @param file 上傳文件
*/
public static boolean post(String path, Map<String, String> params, FormFile[] files) throws Exception{
final String BOUNDARY = "---------------------------7da2137580612"; //數據分隔線
final String endline = "--" + BOUNDARY + "--\r\n";//數據結束標志
int fileDataLength = 0;
for(FormFile uploadFile : files){//得到文件類型數據的總長度
StringBuilder fileExplain = new StringBuilder();
fileExplain.append("--");
fileExplain.append(BOUNDARY);
fileExplain.append("\r\n");
fileExplain.append("Content-Disposition: form-data;name=\""+ uploadFile.getParameterName()+"\";filename=\""+ uploadFile.getFilname() + "\"\r\n");
fileExplain.append("Content-Type: "+ uploadFile.getContentType()+"\r\n\r\n");
fileExplain.append("\r\n");
fileDataLength += fileExplain.length();
if(uploadFile.getInStream()!=null){
fileDataLength += uploadFile.getFile().length();
}else{
fileDataLength += uploadFile.getData().length;
}
}
StringBuilder textEntity = new StringBuilder();
for (Map.Entry<String, String> entry : params.entrySet()) {//構造文本類型參數的實體數據
textEntity.append("--");
textEntity.append(BOUNDARY);
textEntity.append("\r\n");
textEntity.append("Content-Disposition: form-data; name=\""+ entry.getKey() + "\"\r\n\r\n");
textEntity.append(entry.getValue());
textEntity.append("\r\n");
}
//計算傳輸給伺服器的實體數據總長度
int dataLength = textEntity.toString().getBytes().length + fileDataLength + endline.getBytes().length;
URL url = new URL(path);
int port = url.getPort()==-1 ? 80 : url.getPort();
Socket socket = new Socket(InetAddress.getByName(url.getHost()), port);
OutputStream outStream = socket.getOutputStream();
//下面完成HTTP請求頭的發送
String requestmethod = "POST "+ url.getPath()+" HTTP/1.1\r\n";
outStream.write(requestmethod.getBytes());
String accept = "Accept: image/gif, image/jpeg, image/pjpeg, image/pjpeg, application/x-shockwave-flash, application/xaml+xml, application/vnd.ms-xpsdocument, application/x-ms-xbap, application/x-ms-application, application/vnd.ms-excel, application/vnd.ms-powerpoint, application/msword, */*\r\n";
outStream.write(accept.getBytes());
String language = "Accept-Language: zh-CN\r\n";
outStream.write(language.getBytes());
String contenttype = "Content-Type: multipart/form-data; boundary="+ BOUNDARY+ "\r\n";
outStream.write(contenttype.getBytes());
String contentlength = "Content-Length: "+ dataLength + "\r\n";
outStream.write(contentlength.getBytes());
String alive = "Connection: Keep-Alive\r\n";
outStream.write(alive.getBytes());
String host = "Host: "+ url.getHost() +":"+ port +"\r\n";
outStream.write(host.getBytes());
//寫完HTTP請求頭後根據HTTP協議再寫一個回車換行
outStream.write("\r\n".getBytes());
//把所有文本類型的實體數據發送出來
outStream.write(textEntity.toString().getBytes());
//把所有文件類型的實體數據發送出來
for(FormFile uploadFile : files){
StringBuilder fileEntity = new StringBuilder();
fileEntity.append("--");
fileEntity.append(BOUNDARY);
fileEntity.append("\r\n");
fileEntity.append("Content-Disposition: form-data;name=\""+ uploadFile.getParameterName()+"\";filename=\""+ uploadFile.getFilname() + "\"\r\n");
fileEntity.append("Content-Type: "+ uploadFile.getContentType()+"\r\n\r\n");
outStream.write(fileEntity.toString().getBytes());
if(uploadFile.getInStream()!=null){
byte[] buffer = new byte[1024];
int len = 0;
while((len = uploadFile.getInStream().read(buffer, 0, 1024))!=-1){
outStream.write(buffer, 0, len);
}
uploadFile.getInStream().close();
}else{
outStream.write(uploadFile.getData(), 0, uploadFile.getData().length);
}
outStream.write("\r\n".getBytes());
}
//下面發送數據結束標志,表示數據已經結束
outStream.write(endline.getBytes());
BufferedReader reader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
if(reader.readLine().indexOf("200")==-1){//讀取web伺服器返回的數據,判斷請求碼是否為200,如果不是200,代表請求失敗
return false;
}
outStream.flush();
outStream.close();
reader.close();
socket.close();
return true;
}
/**
*單文件上傳
* 提交數據到伺服器
* @param path 上傳路徑(註:避免使用localhost或127.0.0.1這樣的路徑測試,因為它會指向手機模擬器,你可以使用http://www.itcast.cn或http://192.168.1.10:8080這樣的路徑測試)
* @param params 請求參數 key為參數名,value為參數值
* @param file 上傳文件
*/
public static boolean post(String path, Map<String, String> params, FormFile file) throws Exception{
return post(path, params, new FormFile[]{file});
}
}
『捌』 安卓HTML5,多文件上傳不支持么
Android web對於input-file的支持不太好,,到了android 4.4是連選擇文件的窗口都打不開了,我以前有試過,這個如果你是app裡面嵌入webview,建議上傳文件這一環節交給原生去做,原生上傳好文件給到web文件信息。
如果是純webapp的話,微信可以用公眾平台提供的js api,裡面有上傳圖片的介面.其它的web網頁就沒什麼好的方式了。
『玖』 Android上大文件傳輸到伺服器,最大能傳輸多大的文件
Android 上傳時, 雖然他的定義是long型的, 但是位元組長度還是會受到 Integer.Max的影響,所以上傳是多隻能傳 2.1G 的文件.
『拾』 android實現文件上傳的功能
我是這樣做的
Intent intent = new Intent(Intent.ACTION_GET_CONTENT);
intent.setType("*/*");
intent.addCategory(Intent.CATEGORY_OPENABLE);
startActivityForResult(Intent.createChooser(intent, "請選擇一個要上傳的文件"), 1);
然後選擇文件後調用
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (resultCode == Activity.RESULT_OK) {
Uri uri = data.getData();
String url= uri.toString();
}
}
獲得路徑,根據路徑調用
public String convertCodeAndGetText(String str_filepath) {// 轉碼\
try {
File file1 = new File(str_filepath);
file_name = file1.getName();
FileInputStream in = new FileInputStream(file1);
byte[] buffer = new byte[(int) file1.length() + 100];
int length = in.read(buffer);
load = Base64.encodeToString(buffer, 0, length,
Base64.DEFAULT);
in.close();
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return load;
}
對文件進行編碼