Android4.4 WebAPI实现拍照上传功能_Android

网上有很多关于拍照上传的实现方法,如果用新版本android去运行有可能会发现根本实现不了。主要原因是android从4.4版本开始通过intent.ACTION_GET_CONTENT打开选择器后,getData()返回的URI没有包含真实的文件路径,而是像这样“content://com.android.providers.media.documents/document/image:1234”,以至于用传统的方式找不到图片的路径。最简单的解决办法是用intent.ACTION_PICK代替intent.ACTION_GET_CONTENT。

下面给出4.4版本后拍照上传的具体实现方法: 

第一步:点击拍照按钮代码 

    //点击拍照
    btnHeadCamera.setOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View view) {
        Intent itCamera=new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
        startActivityForResult(itCamera,0);
      }
    });

第二步:保存拍照图片代码 

@Override
  protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    switch (requestCode){
      case 0://拍照
        savePhoto(data);
        break;
    }
    super.onActivityResult(requestCode, resultCode, data);
  }

  final String SAVE_PATH=Environment.getExternalStorageDirectory()+"/my_head.jpg"; //拍照后保存路径   //保存图片  public void savePhoto(Intent it){
    Bundle bundle=it.getExtras();
    if(bundle!=null){
      Bitmap photo = bundle.getParcelable("data");
      imgHead.setImageBitmap(photo);
      File fileHead=new File(SAVE_PATH);
      try {
        if(Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)){
          if(!fileHead.getParentFile().exists()){
            fileHead.getParentFile().mkdir();
          }
          BufferedOutputStream bos=new BufferedOutputStream(new FileOutputStream(fileHead));
          photo.compress(Bitmap.CompressFormat.JPEG,80,bos);
          bos.flush();
          bos.close();
        }else {
          Toast toast = Toast.makeText(HeadPhotoActivity.this, "保存失败!", Toast.LENGTH_SHORT);
          toast.setGravity(Gravity.CENTER, 0, 0);
          toast.show();
        }
      }catch (FileNotFoundException e){
        e.printStackTrace();
      }catch (IOException e){
        e.printStackTrace();
      }
    }
  }

第三步:上传图片代码 

String SERVER_URL = Config.PhotoAPI+"/UploadImage";//上传的服务端API地址btnHeadCancel.setOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View view) {
        new Thread(new Runnable() {
          @Override
          public void run() {
            File file = new File(SAVE_PATH);
            Message msg = new Message();
            msg.what = 0;
            if(file!=null) {
              try {
               int re = ImageUtils.uploadForm(file, SERVER_URL);
                msg.obj = re;
              } catch (IOException ex) {
                msg.obj = 0;
                Toast.makeText(HeadPhotoActivity.this, "上传失败", Toast.LENGTH_SHORT).show();
              }
              handler.sendMessage(msg);
            }else {
              Toast.makeText(HeadPhotoActivity.this, "找不到上传图片", Toast.LENGTH_SHORT).show();
            }
          }
        }).start();
      }
    });
final Handler handler=new Handler(){
      @Override
      public void handleMessage(Message msg) {
        switch (msg.what) {
          case 0:
            if ((int)msg.obj == 1) {
              Toast.makeText(HeadPhotoActivity.this, "上传成功", Toast.LENGTH_SHORT).show();
            } else {
              Toast.makeText(HeadPhotoActivity.this, "上传失败", Toast.LENGTH_SHORT).show();
            }
            break;
        }

      }
    };
/**
   *
   * @param uploadFile
   *      需要上传的文件
   * @param serverUrl
   *      上传的服务器的路径
   * @throws IOException
   */
  public static int uploadForm(File uploadFile, String serverUrl)
      throws IOException {
    int re=0;

    String fileName = uploadFile.getName();
    StringBuilder sb = new StringBuilder();
    sb.append("--" + BOUNDARY + "\r\n");
    sb.append("Content-Disposition: form-data; name=\"" + fileName
        + "\"; filename=\"" + fileName + "\"" + "\r\n");
    sb.append("Content-Type: image/jpeg" + "\r\n");
    sb.append("\r\n");

    byte[] headerInfo = sb.toString().getBytes("UTF-8");
    byte[] endInfo = ("\r\n--" + BOUNDARY + "--\r\n").getBytes("UTF-8");
    System.out.println(sb.toString());
    URL url = new URL(serverUrl);
    HttpURLConnection conn = (HttpURLConnection) url.openConnection();
    conn.setRequestMethod("POST");
    conn.setRequestProperty("Content-Type",
        "multipart/form-data; boundary=" + BOUNDARY);
    conn.setRequestProperty("Content-Length", String
        .valueOf(headerInfo.length + uploadFile.length()
            + endInfo.length));
    conn.setDoOutput(true);

    OutputStream out = conn.getOutputStream();
    InputStream in = new FileInputStream(uploadFile);
    out.write(headerInfo);

    byte[] buf = new byte[1024];
    int len;
    while ((len = in.read(buf)) != -1)
      out.write(buf, 0, len);

    out.write(endInfo);
    in.close();
    out.close();
    if (conn.getResponseCode() == 200) {
      re=1;
    }
    return re;
  }

最后给出服务端WebAPI代码: 

    [HttpPost]
    public async Task<HttpResponseMessage> UploadImage()
    {string filePath = "~\\UploadFiles\\Photo";
      // 取得文件夹
      string dir = HttpContext.Current.Server.MapPath(filePath);
      //如果不存在文件夹,就创建文件夹
      if (!Directory.Exists(dir))
        Directory.CreateDirectory(dir);
      if (!Request.Content.IsMimeMultipartContent("form-data"))
      {
        throw new HttpResponseException(HttpStatusCode.UnsupportedMediaType);
      }
      var provider = new CustomMultipartFormDataStreamProvider(dir);
      try
      {
        // Read the form data.
        await Request.Content.ReadAsMultipartAsync(provider);
        foreach (MultipartFileData file in provider.FileData)
        {
          //file.Headers.ContentDisposition.FileName;//上传文件前的文件名
          //file.LocalFileName;//上传后的文件名
          Photo p = new Photo();
          p.ImgInfo = file.LocalFileName.Substring(file.LocalFileName.LastIndexOf("\\"));
          p.Sort = "员工相册";
          p.AddUser = "admin";
          p.AddTime = DateTime.Now;
          p.Url = filePath + p.ImgInfo;

          db.Photo.Add(p);
          db.SaveChanges();
        }
        return Request.CreateResponse(HttpStatusCode.OK);      }
      catch
      {
        return Request.CreateResponse(HttpStatusCode.BadRequest);      }
    }
  //重写上传文件名
  public class CustomMultipartFormDataStreamProvider : MultipartFormDataStreamProvider
  {
    public CustomMultipartFormDataStreamProvider(string path)
      : base(path)
    { }

    public override string GetLocalFileName(System.Net.Http.Headers.HttpContentHeaders headers)
    {
      string fileName = DateTime.Now.ToString("yyyyMMddHHmmssfff");
      return fileName + "_" + headers.ContentDisposition.FileName.Replace("\"", string.Empty);//base.GetLocalFileName(headers);
    }
  }

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

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索webapi
, 拍照上传
Android4.4
微信拍照上传图片api、html5实现拍照上传、cordova实现拍照上传、h5实现拍照上传、webview实现拍照上传,以便于您获取更多的相关知识。

时间: 2025-01-21 04:05:34

Android4.4 WebAPI实现拍照上传功能_Android的相关文章

Android4.4 WebAPI实现拍照上传功能

网上有很多关于拍照上传的实现方法,如果用新版本android去运行有可能会发现根本实现不了.主要原因是android从4.4版本开始通过intent.ACTION_GET_CONTENT打开选择器后,getData()返回的URI没有包含真实的文件路径,而是像这样"content://com.android.providers.media.documents/document/image:1234",以至于用传统的方式找不到图片的路径.最简单的解决办法是用intent.ACTION_P

手机端用HTML5实现拍照上传功能

HTML5实现WAP网站拍照上传功能 做web应用想达到这样的效果: 目前网上发布的教程中,大多数介绍HTML5网页拍照上传都是基于canvas调用摄像头,并转化为数据流进行传输,服务器解码并写入文件.前前后后代码好几百行,影响性能不说,达到的效果也不是我们想要的. 经过分析百度贴吧等网页端的代码,发现实现的技术其实很简单,就是下面这个input: <input type="file" name="pic" id="pic" accept=

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

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

Android仿微信发表说说实现拍照、多图上传功能_Android

本文实例为大家分享了Android仿微信发表说说.心情功能,供大家参考,具体内容如下 既能实现拍照,选图库,多图案上传的案例,目前好多App都有类似微信朋友圈的功能,能过发表说说等附带图片上传.下面的就是实现该功能的过程:大家还没有看过Android Retrofit 2.0框架上传图片解决方案这篇文章,在看今天的就很容易,接在本项目中用到了一个library:photopicker,封装了图片的选择功能,是否选相机,还有选中图片后可以查看图片的功能.   一. 首先:将photopicker到

php实现视频拍照上传头像功能实例代码

现在手机拍照很火,那么如何使用手机拍照并上传头像呢?原因很简单,就是数据传递,首先手机传递照片信息,这个就不是post传递 也不是get函数传递, 这个另外一种数据格式传递,使用的是$GLOBALS ['HTTP_RAW_POST_DATA'],这个系统函数跟post很相似,但是$GLOBALS ['HTTP_RAW_POST_DATA']支持的数据格式更丰富些,详细的区别请自己百度谷歌. 设计流程就是: $GLOBALS ['HTTP_RAW_POST_DATA']传递照片数据流(二进制)–>

网上惊现曝工资软件 任何人都能把工资条拍照上传

最近出了一个神奇的曝工资软件,任何人都可以把自己的工资条拍照上传到里面,而且还可以查看上千条职位的信息,被网友称作是神器. 这款软件在设计与运营商也颇下精力,比如产品提供了社交分享,用户分享后可以获得更多查询次数.软件偶尔也会在小米社区做活动营销,依靠一台红米赚了 18000 条回复. 据了解,该软件的核心成员只有5个人,包括3个产品以及运营人员和2个开发人员.谈及用户对隐私泄露的顾虑,曝工资团队表示不会对用户个别建档,用户上传工资条时也可以主动把姓名和工号抹去,所以不必太过担心. 目前,这款曝

急!怎样在j2ee中实现摄像头拍照上传?

问题描述 哪位知道怎样在j2ee中实现摄像头拍照上传?着急啊! 解决方案 解决方案二:光J2EE做不了这活,因为你需要有本地代码(exe/dll/ocx)来驱动摄像头.解决方案三:该回复于2011-04-29 09:15:29被版主删除解决方案四:拍照后把相片存在相应的位置然后使用文件上传不可以么?解决方案五:该回复于2011-04-29 09:39:40被版主删除解决方案六:该回复于2011-04-29 09:47:03被版主删除解决方案七:该回复于2011-04-29 09:32:45被版主

Spring 文件上传功能

本篇文章,我们要来做一个Spring的文件上传功能: 1. 创建一个Maven的web工程,然后配置pom.xml文件,增加依赖: 1 2 3 4 5 <dependency>     <groupId>org.springframework.boot</groupId>     <artifactId>spring-boot-starter-web</artifactId>     <version>1.0.2.RELEASE<

如何在Web页面中集成文件上传功能

当前,个人主页制作非常流行.当用户开发好自己的页面时,需要将文件传输到服务器上,解决这个问题的方法之一是运行FTP服务器并将每个用户的FTP默认目录设为用户的Web主目录,这样用户就能运行FTP客户程序并上传文件到指定的 Web目录.由于Windows NT 和 Windows98均不提供直接的基于窗口形式的FTP客户程序,用户必须懂得如何使用基于命令行的FTP客户,或掌握一种新的基于窗口形式的FTP客户程序.因此,这种解决方案仅对熟悉FTP且富有经验的用户来说是可行的. 如果我们能把文件上传功