Android实现头像上传功能

之前做这个头像上传功能还是花了好多时间的,今天我将我的代码分享给大家先看效果图

首先看上传图片的工具类,一点都没有少复制就可以用

**
 * Created by Administrator on 2016/7/28.
 * 上传图片工具类
 */
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 在网页上<input type=file name=xxx/> xxx就是这里的fileKey
 * @param RequestURL 请求的URL
 */
 public void uploadFile(String filePath, String fileKey, String RequestURL,
    Map<String, String> 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 在网页上<input type=file name=xxx/> xxx就是这里的fileKey
 * @param RequestURL 请求的URL
 */
 public void uploadFile(final File file, final String fileKey,
    final String RequestURL, final Map<String, String> 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<String, String> 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<String> 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);
  }
  String s = sb1.toString();
  result = s;
  Log.e(TAG, "result : " + result);
  sendMessage(UPLOAD_SUCCESS_CODE, "上传结果:"
   + result);
  return;
  } else {
  Log.e(TAG, "request error" + res);
  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 static 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 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 {

 }

 /**
 * 将Bitmap转换成文件
 * 保存文件
 *
 * @param bm
 * @param fileName
 * @throws IOException
 */
 public static File saveFile(Bitmap bm, String path, String fileName) throws IOException {
 File dirFile = new File(path);
 if (!dirFile.exists()) {
  dirFile.mkdir();
 }
 File myCaptureFile = new File(path, fileName);
 BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(myCaptureFile));
 bm.compress(Bitmap.CompressFormat.JPEG, 80, bos);
 bos.flush();
 bos.close();
 return myCaptureFile;
 }

}

从相册获取图片的方法

/**
 * 从相册选择图片来源
 */
private void getPhoto() {
 Intent intent = new Intent(Intent.ACTION_PICK, android.provider.MediaStore.Images.Media.EXTERNAL_CONTENT_URI);
 intent.setDataAndType(MediaStore.Images.Media.EXTERNAL_CONTENT_URI,
  "image/*");
 startActivityForResult(intent, PHOTO_REQUEST);
}

从系统相机拍照获取照片

/**
 * 从系统相机选择图片来源
 */
private void getCamera() {
 Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);

 // 下面这句指定调用相机拍照后的照片存储的路径
 intent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(new File(
  Environment.getExternalStorageDirectory(), "hand.jpg")));
 startActivityForResult(intent, CAMERA_REQUEST);
}

调用系统裁剪工具裁剪图片

/****
 * 调用系统自带切图工具对图片进行裁剪
 * 微信也是
 *
 * @param uri
 */
private void photoClip(Uri uri) {
 // 调用系统中自带的图片剪裁
 Intent intent = new Intent("com.android.camera.action.CROP");
 intent.setDataAndType(uri, "image/*");
 // 下面这个crop=true是设置在开启的Intent中设置显示的VIEW可裁剪
 intent.putExtra("crop", "true");
 // aspectX aspectY 是宽高的比例
 intent.putExtra("aspectX", 1);
 intent.putExtra("aspectY", 1);
 // outputX outputY 是裁剪图片宽高
 intent.putExtra("outputX", 150);
 intent.putExtra("outputY", 150);
 intent.putExtra("return-data", true);
 startActivityForResult(intent, PHOTO_CLIP);
}

上传服务器的方法

/**
 * 上传图片到服务器
 */
private void toUploadFile() {
 pd = ProgressDialog.show(this, "", "正在上传文件...");
 pd.show();
 String fileKey = "avatarFile";
 UploadUtil uploadUtil = UploadUtil.getInstance();
 uploadUtil.setOnUploadProcessListener(MainActivity.this); //设置监听器监听上传状态

 Map<String, String> params = new HashMap<String, String>();//上传map对象
 params.put("userId", "");
 uploadUtil.uploadFile(filepath, fileKey, "上传头像的地址", params);
 Toast.makeText(this, "上传成功", Toast.LENGTH_LONG).show();
}

重新服务器响应方法

/**
 * 上传服务器响应回调
 */
@Override
public void onUploadDone(int responseCode, String message) {
 //上传完成响应
 pd.dismiss();
 Message msg = Message.obtain();
 msg.what = UPLOAD_FILE_DONE;
 msg.arg1 = responseCode;
 msg.obj = message;
}

@Override
public void onUploadProcess(int uploadSize) {
 //上传中
 Message msg = Message.obtain();
 msg.what = UPLOAD_IN_PROCESS;
 msg.arg1 = uploadSize;
}

@Override
public void initUpload(int fileSize) {
 //准备上传
 Message msg = Message.obtain();
 msg.what = UPLOAD_INIT_PROCESS;
 msg.arg1 = fileSize;
}

重写这些方法需要实现接口

public class MainActivity extends AppCompatActivity implements View.OnClickListener, UploadUtil.OnUploadProcessListener {

重写onActivityResult获取数据

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
 super.onActivityResult(requestCode, resultCode, data);
 switch (requestCode) {
 case CAMERA_REQUEST:
  switch (resultCode) {
  case -1://-1表示拍照成功
   File file = new File(Environment.getExternalStorageDirectory()
    + "/hand.jpg");//保存图片
   if (file.exists()) {
   //对相机拍照照片进行裁剪
   photoClip(Uri.fromFile(file));
   }
  }
  break;

 case PHOTO_REQUEST://从相册取
  if (data != null) {
  Uri uri = data.getData();
  //对相册取出照片进行裁剪
  photoClip(uri);

  }
  break;
 case PHOTO_CLIP:
  //完成
  if (data != null) {

  Bundle extras = data.getExtras();
  if (extras != null) {
   Bitmap photo = extras.getParcelable("data");
   try {
   //获得图片路径
   filepath = UploadUtil.saveFile(photo, Environment.getExternalStorageDirectory().toString(), "hand.jpg");
   //上传照片
   toUploadFile();
   } catch (IOException e) {
   e.printStackTrace();
   }
   //上传完成将照片写入imageview与用户进行交互
   mImageView.setImageBitmap(photo);
  }
  }
  break;
 }
}

源码下载:Android实现头像上传功能

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android头像上传功能的实现代码(获取头像加剪切)

    因为项目中需要用到头像上传的功能,所以就下个Ddmo先来实现下. demo我是类似仿微信的,在一个GridView中展示所有的图片,其中第一个item可以去照相:获取到图片后再进行剪切. 图片的剪切是从网上找的感觉不错就用,暂时也没有测试. 获取图片可以用:https://github.com/lovetuzitong/MultiImageSelector来实现 这里的圆形图像是用https://github.com/hdodenhof/CircleImageView来实现的 Demo写的比较粗

  • Android retrofit上传文件实例(包含头像)

    上传文件主要就是通过接口 1.AndroidMainfest.xml中加入权限 <uses-permission android:name="android.permission.INTERNET"/> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/> <uses-permission android:name="android

  • Android实现本地上传图片并设置为圆形头像

    先从本地把图片上传到服务器,然后根据URL把头像处理成圆形头像. 因为上传图片用到bmob的平台,所以要到bmob(http://www.bmob.cn)申请密钥. 效果图: 核心代码: 复制代码 代码如下: public class MainActivity extends Activity {         private ImageView iv;         private String appKey="";                //填写你的Applicatio

  • Android个人中心的头像上传,图片编码及截取实例

    首先需要有网络权限,然后我们这里匹配的网络请求是之前封装好的Okhttp. 非常的简单方便,直接复制进去,依赖一下包,然后调用方法即可. 这里是把图片转换成Base64.decode(imageString, Base64.DEFAULT); 转成Base64编码上传.具体内容也不少,需要完全整明白,还是要花点时间慢慢看的. 先看看简单的效果图: 那么万事具备,只欠东风了.直接上代码: public class MainActivity extends AppCompatActivity imp

  • Android实现头像上传功能

    之前做这个头像上传功能还是花了好多时间的,今天我将我的代码分享给大家先看效果图 首先看上传图片的工具类,一点都没有少复制就可以用 ** * Created by Administrator on 2016/7/28. * 上传图片工具类 */ public class UploadUtil { private static UploadUtil uploadUtil; private static final String BOUNDARY = UUID.randomUUID().toStrin

  • 针对多用户实现头像上传功能PHP代码 适用于登陆页面制作

    一个网站,其实说白了就是某几个特定功能的组合,而更换用户头像就在这些功能之中.今天就来做个测试,针对不同的用户,实现头像上传功能. -------------------------------------------------------------------------------- 成品图 思路  •针对不同的用户上传头像,我们要为每一个已登录的用户创建一个文件夹,文件夹的名称以当前用户的用户名为准. •用户上传成功后,跳转到用户登录成功后的页面,并刷新用户头像. 登陆页面 表单制作

  • Vue vant-ui使用van-uploader实现头像上传功能

    效果图: 项目中是使用有赞vant-ui框架实现的头像上传替换功能 代码布局结构: <van-row class="sendInfo"> <van-col span="24" class="flex colorf topInfo p20"> <!--左边头像部分--> <van-uploader :after-read="afterCard" :before-read="be

  • vue实现头像上传功能

    本文实例为大家分享了vue实现头像上传的具体代码,供大家参考,具体内容如下 1.创建项目,使用vue-admin-template框架 2.使用vue命令在终端(开发工具VScode)输入npm install,即可按package.json文件下载 3.导入相关工具包,是上传头像的样式更好看 4.在views编写vue文件 <template>   <div class="app-container">       <el-form-item label

  • android实现图片上传功能(springMvc)

    本文实例为大家分享了Android图片上传的具体代码,供大家参考,具体内容如下 Android端: String fileName = tvFilename.getText().toString(); RequestBody description = RequestBody.create( okhttp3.MultipartBody.FORM, fileName); File fileImage = new File(saveFileName); RequestBody requestBody

  • Android实现图片上传功能

    最近在开发中,涉及到用户的意见反馈功能这一方面的开发,需要用户输入的文字或者提交的图片,效果大概类似于微信朋友圈那样的图片选择器,一开始自己找了个用universal-image-loader框架写的,很容实现,但是容易出现内存溢出,并且不好解决,是在没办法,就自己看了一些资料,准备自己写:在这里说下本人实现的思路,进入页面也就是显示选择图片的页面用GridView来实现,点击添加图标的时候,用Dialog实现,给Dialog添加相应的动画就可以了,进入图片展示页面还是用GridView来实现,

  • php实现头像上传预览功能

    本文实例为大家分享了php实现头像上传预览功能的具体代码,供大家参考,具体内容如下 主页面1.php <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>上传头像</title> <style type="text/css"> *{ font-fa

  • Android实现文件上传和下载倒计时功能的圆形进度条

    screenshot 截图展示 import step1. Add it in your root build.gradle at the end of repositories: allprojects { repositories { ... maven { url 'https://jitpack.io' } } } step2. Add the dependency dependencies { compile 'com.github.yanjiabin:ExtendsRingPrigr

  • jQuery插件ImgAreaSelect实现头像上传预览和裁剪功能实例讲解一

    上一节随笔中,我们已经知道了关于jQuery插件ImgAreaSelect基本的知识:那么现在看一下实例: 首先,要知道我们应该实现什么功能? (1)图片能够实现上传预览功能 (2)拖拽裁剪图片,使其能够显示裁剪后的区域 (3)显示要裁剪区域的坐标 其次,该如何引用该插件呢? 那就具体看一下吧! 第一步:先将样式和文件包引入(根据你自己的位置引入) <!--引入imgareaselect的css样式--> <link rel="stylesheet" type=&qu

  • Android 高仿微信朋友圈拍照上传功能

    模仿微信朋友圈发布动态,输入文字支持文字多少高度自增,有一个最小输入框高度,输入文字有限制,不过这些都很easy! 1. PhotoPicker的使用 这是一个支持选择多张图片,点击图片放大,图片之间左右滑动互相切换的库,同时支持图片删除的库,效果类似微信. (1) 添加PhotoPicker的架包 (2) 使用 选择图片:安卓6.0以后需要在代码中添加读写sd卡和相机的权限 当然清单文件中也需要添加的 PhotoPicker.builder() .setPhotoCount(maxPhoto)

随机推荐