android拍照上传照片,android 选择照片/拍照 并上传图片到服务器源码(含服务器端接收源码)..._牛新哲的博客-程序员秘密

技术标签: android拍照上传照片  

【实例简介】android上传图片,服务器端用C#语音接收

【实例截图】

7e8f623b861ee4823e664f2bf43fbed9.png

0bf6ee1f001922bd05239acc63b876dd.png

8543dc5b4033e617ada0d5cd02a1564a.png

【核心代码】

下面是服务器端核心代码:

///

/// ProPicUpload 的摘要说明

///

public class ProPicUpload : IHttpHandler

{

public void ProcessRequest(HttpContext context)

{

context.Response.ContentType = "text/plain";

context.Response.Charset = "utf-8";

HttpPostedFile file = context.Request.Files["Filedata"];

if (context.Request["type"] == "android")

{

if (file != null)

{

//上传图片方法就不贴了

//通过file就可以保存到服务器

context.Response.Write("/upload/" "," "文件名.jpg");

}

}

}

public bool IsReusable

{

get

{

return false;

}

}

}

下面是客户端代码

package com.spring.sky.image.upload.network;

import java.io.BufferedReader;

import java.io.DataOutputStream;

import java.io.File;

import java.io.FileInputStream;

import java.io.IOException;

import java.io.InputStream;

import java.io.InputStreamReader;

import java.net.HttpURLConnection;

import java.net.MalformedURLException;

import java.net.URL;

import java.util.Iterator;

import java.util.Map;

import java.util.UUID;

import org.apache.http.HttpEntity;

import org.apache.http.HttpResponse;

import org.apache.http.HttpStatus;

import org.apache.http.client.HttpClient;

import org.apache.http.client.methods.HttpPost;

import org.apache.http.entity.mime.MultipartEntity;

import org.apache.http.entity.mime.content.FileBody;

import org.apache.http.entity.mime.content.StringBody;

import org.apache.http.impl.client.DefaultHttpClient;

import com.spring.sky.image.upload.CustomMultipartEntity;

import com.spring.sky.image.upload.CustomMultipartEntity.ProgressListener;

import android.util.Log;

/**

*

* 上传工具类

*

* @author spring sky

* Email :[email protected]

* QQ: 840950105

* 支持上传文件和参数

*/

public class UploadUtil {

private static UploadUtil uploadUtil;

private static final String BOUNDARY = UUID.randomUUID().toString(); // 边界标识

// 随机生成

private static final String PREFIX = "--";

private static final String LINE_END = "\r\n";

private static final String CONTENT_TYPE = "multipart/form-data"; // 内容类型

private UploadUtil() {

}

/**

* 单例模式获取上传工具类

*

* @return

*/

public static UploadUtil getInstance() {

if (null == uploadUtil) {

uploadUtil = new UploadUtil();

}

return uploadUtil;

}

private static final String TAG = "UploadUtil";

private int readTimeOut = 10 * 1000; // 读取超时

private int connectTimeout = 10 * 1000; // 超时时间

/***

* 请求使用多长时间

*/

private static int requestTime = 0;

private static final String CHARSET = "utf-8"; // 设置编码

/***

* 上传成功

*/

public static final int UPLOAD_SUCCESS_CODE = 1;

/**

* 文件不存在

*/

public static final int UPLOAD_FILE_NOT_EXISTS_CODE = 2;

/**

* 服务器出错

*/

public static final int UPLOAD_SERVER_ERROR_CODE = 3;

protected static final int WHAT_TO_UPLOAD = 1;

protected static final int WHAT_UPLOAD_DONE = 2;

/**

* android上传文件到服务器

*

* @param filePath

* 需要上传的文件的路径

* @param fileKey

* 在网页上 xxx就是这里的fileKey

* @param RequestURL

* 请求的URL

*/

public void uploadFile(String filePath, String fileKey, String RequestURL,

Map param) {

if (filePath == null) {

sendMessage(UPLOAD_FILE_NOT_EXISTS_CODE, "文件不存在");

return;

}

try {

File file = new File(filePath);

uploadFile(file, fileKey, RequestURL, param);

} catch (Exception e) {

sendMessage(UPLOAD_FILE_NOT_EXISTS_CODE, "文件不存在");

e.printStackTrace();

return;

}

}

/**

* android上传文件到服务器

*

* @param file

* 需要上传的文件

* @param fileKey

* 在网页上 xxx就是这里的fileKey

* @param RequestURL

* 请求的URL

*/

public void uploadFile(final File file, final String fileKey,

final String RequestURL, final Map param) {

if (file == null || (!file.exists())) {

sendMessage(UPLOAD_FILE_NOT_EXISTS_CODE, "文件不存在");

return;

}

Log.i(TAG, "请求的URL=" RequestURL);

Log.i(TAG, "请求的fileName=" file.getName());

Log.i(TAG, "请求的fileKey=" fileKey);

new Thread(new Runnable() { // 开启线程上传文件

@Override

public void run() {

toUploadFile(file, fileKey, RequestURL, param);

}

}).start();

}

private void toUploadFile(File file, String fileKey, String RequestURL,

Map param) {

String result = null;

requestTime = 0;

long requestTime = System.currentTimeMillis();

long responseTime = 0;

try {

URL url = new URL(RequestURL);

HttpURLConnection conn = (HttpURLConnection) url.openConnection();

conn.setReadTimeout(readTimeOut);

conn.setConnectTimeout(connectTimeout);

conn.setDoInput(true); // 允许输入流

conn.setDoOutput(true); // 允许输出流

conn.setUseCaches(false); // 不允许使用缓存

conn.setRequestMethod("POST"); // 请求方式

conn.setRequestProperty("Charset", CHARSET); // 设置编码

conn.setRequestProperty("connection", "keep-alive");

conn.setRequestProperty("user-agent",

"Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1)");

conn.setRequestProperty("Content-Type", CONTENT_TYPE ";boundary="

BOUNDARY);

// conn.setRequestProperty("Content-Type",

// "application/x-www-form-urlencoded");

/**

* 当文件不为空,把文件包装并且上传

*/

DataOutputStream dos = new DataOutputStream(conn.getOutputStream());

StringBuffer sb = null;

String params = "";

/***

* 以下是用于上传参数

*/

if (param != null && param.size() > 0) {

Iterator it = param.keySet().iterator();

while (it.hasNext()) {

sb = null;

sb = new StringBuffer();

String key = it.next();

String value = param.get(key);

sb.append(PREFIX).append(BOUNDARY).append(LINE_END);

sb.append("Content-Disposition: form-data; name=\"")

.append(key).append("\"").append(LINE_END)

.append(LINE_END);

sb.append(value).append(LINE_END);

params = sb.toString();

Log.i(TAG, key "=" params "##");

dos.write(params.getBytes());

// dos.flush();

}

}

sb = null;

params = null;

sb = new StringBuffer();

/**

* 这里重点注意: name里面的值为服务器端需要key 只有这个key 才可以得到对应的文件

* filename是文件的名字,包含后缀名的 比如:abc.png

*/

sb.append(PREFIX).append(BOUNDARY).append(LINE_END);

sb.append("Content-Disposition:form-data; name=\"" fileKey

"\"; filename=\"" file.getName() "\"" LINE_END);

sb.append("Content-Type:image/pjpeg" LINE_END); // 这里配置的Content-type很重要的

// ,用于服务器端辨别文件的类型的

sb.append(LINE_END);

params = sb.toString();

sb = null;

Log.i(TAG, file.getName() "=" params "##");

dos.write(params.getBytes());

/** 上传文件 */

InputStream is = new FileInputStream(file);

onUploadProcessListener.initUpload((int) file.length());

byte[] bytes = new byte[1024];

int len = 0;

int curLen = 0;

while ((len = is.read(bytes)) != -1) {

curLen = len;

dos.write(bytes, 0, len);

onUploadProcessListener.onUploadProcess(curLen);

}

is.close();

dos.write(LINE_END.getBytes());

byte[] end_data = (PREFIX BOUNDARY PREFIX LINE_END)

.getBytes();

dos.write(end_data);

dos.flush();

//

// dos.write(tempOutputStream.toByteArray());

/**

* 获取响应码 200=成功 当响应成功,获取响应的流

*/

int res = conn.getResponseCode();

responseTime = System.currentTimeMillis();

this.requestTime = (int) ((responseTime - requestTime) / 1000);

Log.e(TAG, "response code:" res);

if (res == 200) {

Log.e(TAG, "request success");

InputStream input = conn.getInputStream();

StringBuffer sb1 = new StringBuffer();

int ss;

while ((ss = input.read()) != -1) {

sb1.append((char) ss);

}

result = sb1.toString();

Log.e(TAG, "result : " result);

sendMessage(UPLOAD_SUCCESS_CODE, "上传结果:" result);

return;

} else {

Log.e(TAG, "request error");

sendMessage(UPLOAD_SERVER_ERROR_CODE, "上传失败:code=" res);

return;

}

} catch (MalformedURLException e) {

sendMessage(UPLOAD_SERVER_ERROR_CODE,

"上传失败:error=" e.getMessage());

e.printStackTrace();

return;

} catch (IOException e) {

sendMessage(UPLOAD_SERVER_ERROR_CODE,

"上传失败:error=" e.getMessage());

e.printStackTrace();

return;

}

}

/**

* 发送上传结果

*

* @param responseCode

* @param responseMessage

*/

private void sendMessage(int responseCode, String responseMessage) {

onUploadProcessListener.onUploadDone(responseCode, responseMessage);

}

/**

* 下面是一个自定义的回调函数,用到回调上传文件是否完成

*

* @author shimingzheng

*

*/

public interface OnUploadProcessListener {

/**

* 上传响应

*

* @param responseCode

* @param message

*/

void onUploadDone(int responseCode, String message);

/**

* 上传中

*

* @param uploadSize

*/

void onUploadProcess(int uploadSize);

/**

* 准备上传

*

* @param fileSize

*/

void initUpload(int fileSize);

}

private static OnUploadProcessListener onUploadProcessListener;

public void setOnUploadProcessListener(

OnUploadProcessListener onUploadProcessListener) {

this.onUploadProcessListener = onUploadProcessListener;

}

public int getReadTimeOut() {

return readTimeOut;

}

public void setReadTimeOut(int readTimeOut) {

this.readTimeOut = readTimeOut;

}

public int getConnectTimeout() {

return connectTimeout;

}

public void setConnectTimeout(int connectTimeout) {

this.connectTimeout = connectTimeout;

}

/**

* 获取上传使用的时间

*

* @return

*/

public static int getRequestTime() {

return requestTime;

}

public static interface uploadProcessListener {

}

private static long totalSize = 0;

/**

* 提交参数里有文件的数据

*

* @param url

* 服务器地址

* @param param

* 参数

* @return 服务器返回结果

* @throws Exception

*/

public String uploadSubmit(String url, Map param,

File file, String fileKey) throws Exception {

HttpPost post = new HttpPost(url);

// MultipartEntity entity = new MultipartEntity();

CustomMultipartEntity entity = new CustomMultipartEntity(

new ProgressListener() {

@Override

public void transferred(long num) {

onUploadProcessListener

.onUploadProcess((int) ((num / (float)totalSize) * 100));

}

});

if (param != null && !param.isEmpty()) {

for (Map.Entry entry : param.entrySet()) {

if (entry.getValue() != null

&& entry.getValue().trim().length() > 0) {

entity.addPart(entry.getKey(),

new StringBody(entry.getValue()));

}

}

}

// 添加文件参数

if (file != null && file.exists()) {

entity.addPart(fileKey, new FileBody(file));

}

totalSize = entity.getContentLength();

post.setEntity(entity);

HttpClient httpClient = new DefaultHttpClient();

HttpResponse response = httpClient.execute(post);

int stateCode = response.getStatusLine().getStatusCode();

StringBuffer sb = new StringBuffer();

if (stateCode == HttpStatus.SC_OK) {

HttpEntity result = response.getEntity();

if (result != null) {

InputStream is = result.getContent();

BufferedReader br = new BufferedReader(

new InputStreamReader(is));

String tempLine;

while ((tempLine = br.readLine()) != null) {

sb.append(tempLine);

}

}

}

post.abort();

return sb.toString();

}

}

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_42561464/article/details/117617600

智能推荐

[python] - 读取文件内容,并输出_weixin_34112900的博客-程序员秘密

1.读取文件,并逐行输出内容,代码如下:# coding=gbkimport ospath = 'E:\python_practice'os.chdir(path)fname = raw_input('Enter filename: ')printtry: fobj = open(fname, 'r')except IOError, e: ...

linux环境下的mount命令到底有什么玄机_AlbertS的博客-程序员秘密

linux 环境下的 `mount` 命令可以挂载一个文件系统,这个命令目前是我所知命令中最陌生的一个,至今没有使用过,真的一次都没有挂载过,平时用的最多是的 Windwos 系统,完全不需要挂载,安装新硬盘自动就会出现盘符,稍微复杂点就是通过磁盘管理器来分区,或者使用魔术分区助手搞一点复杂的分区或格式化操作...

hdu 3117 Fibonacci Numbers_the fibonacci sequence is the sequence of numbers _ITAK的博客-程序员秘密

点击此处即可传送到hdu 3117 **Fibonacci Numbers**Problem DescriptionThe Fibonacci sequence is the sequence of numbers such that every element is equal to the sum of the two previous elements, e

Google Earth常用功能详解-程序员秘密

文件 导入是最重要的功能,可以导入路径、图像、模型。 编辑 复制,如果选中路径对象将会复制为KML的XML语言文本。 复制为航迹,可以复制路径,但不清楚用途。 复制图像就是将当前窗口截屏。 复制视图位置会将当前的经纬度以度,分,秒的格式复制到剪贴板。 重命名是为除我的地点、临时位置不可用外,其余的都可以用。 快照视图是所有对象可用的,包括文件夹、地标、图像、路径、游览,只有在左侧窗格选中对象,这个功能才可以用。 按名称排

Qt如何向文本框格式化添加数字变量及添加转态提示 - Qt学习_qt文本框输入数字_逸璞丷昊的博客-程序员秘密

运用 QString::arg() 函数,可以向Qt中的各类控件和文本框中添加需要显示的数字变量,实现了数字的格式化显示。调用控件成员函数 setStatusTip() 设置提示信息。格式化添加数字比如要向QLineEdit类对象中格式化添加数字,使用如下代码即可ui->lineEdit->setText(tr("Enter the messa...

随便推点

JavaScript 学习笔记(四)-- BOM_Agoni Lay的博客-程序员秘密

BOMBrowser Object Model定义了浏览器的接口BOM对象:Window,History,Navigator,Screen,Location属性滚动条滚动距离pageXOffset / pageYOffset求滚动条滚动距离,返回 number 类型的数值,单位是像素pageXOffset --> 横向pageYOffset --> 纵向兼容性:IE9以下不兼容document.body/documentElement.scorllLeft

Linux内核移植初探_a619861986的博客-程序员秘密

内核移植的梯度:初级:根据芯片公司的参考配置,编译开发板内核并了解执行过程中极:添加内核驱动的方式方法高级:修改或添加BSP包linux内核特性:可移植性强、支持的硬件平台广泛;超强的网络功能;多任务多用户系统;模块化的设计五大子系统:进程管理;内存管理;文件系统;网络协议;设备管理内核获取路径:芯片厂商、内核源码官方linux内核的目录结构层次结...

mt7620 openwrt编译,修改dts文件_openwrt dts_实业创业者的博客-程序员秘密

对于 MT7620a 。必须修改dts文件,否则编译出来的固件将无法启动:vi target/linux/ramips/dts/MT7620a.dts11把 [email protected][email protected] 修改成下面的内容: [email protected] { status = "okay";

21-z-index_aifen8858的博客-程序员秘密

z-index这个东西非常简单,它有四大特性,每个特性你记住了,页面布局就不会出现找不到盒子的情况。z-index 值表示谁压着谁,数值大的压盖住数值小的,只有定位了的元素,才能有z-index,也就是说,不管相对定位,绝对定位,固定定位,都可以使用z-index,而浮动元素不能使用z-indexz-index值没有单位,就是一个正整数,默认的z-index值为...

JWT和token是什么?如何利用token进行身份验证?_clear0217的博客-程序员秘密

有没有一种不需要自己存放session信息就能实现身份验证的方式?使用token就可以!JWT就是这种方式实现的,通过这种方式服务器端就不需要保存session数据了,只要在客户端保存服务端返回给用户token就可以了,扩展性得到提升。这种方式会带来一些麻烦,比如需要我们保证保存session信息服务器的可用性、不适合移动端等。JWT本质上就是一段签名的JSON格式的数据。由于他是带有签名的,因此接受者便可以验证他的真实性。身份验证服务响应并返回了签名的jwt,上面包含了用户是谁的内容。

类加载器(ClassLoader)_yanzhenluan的博客-程序员秘密

1.1.1.4 类加载器(ClassLoader) 1.1.1.4.1 基础知识 静态库、动态连接库 程序编制一般需经编辑、编译、连接、加载和运行几个步骤。在我们的应用中,有一些公共代码是需要反复使用,就把这些代码编译为“库”文件;在连接步骤中,连接器将从库文件取得所需的代码,复制到生成的可执行文件中。这种库称为静态库,其特点是可执行文件中包含了库代码的一份完整拷贝;缺点就是被多次使用

推荐文章

热门文章

相关标签