文档章节

Android 通过Base64上传图片到服务器

ForingY
 ForingY
发布于 2016/08/01 14:20
字数 504
阅读 12
收藏 0

前台图片处理:(传Bitmap对象即可)

/** 
 * 通过Base32将Bitmap转换成Base64字符串 
 * @param bit 
 * @return 
 */  
public String Bitmap2StrByBase64(Bitmap bit){  
   ByteArrayOutputStream bos=new ByteArrayOutputStream();  
   bit.compress(CompressFormat.JPEG, 40, bos);//参数100表示不压缩  
   byte[] bytes=bos.toByteArray();  
   return Base64.encodeToString(bytes, Base64.DEFAULT);  
}  

前台发送数据:(調用setImgByStr()方法,第一個參數imgStr 为Bitmap转成Base64的字符串,第二个参数imgName为图片的名字,包含后缀名.jpg)

public static String host = "http://192.168.1.166:8080/ImageServer/";  
  
public static String getContent(String url) throws Exception {  
  
    StringBuilder sb = new StringBuilder();  
  
    HttpClient client = new DefaultHttpClient();  
    HttpParams httpParams = client.getParams();  
    // 设置网络超时参数  
    HttpConnectionParams.setConnectionTimeout(httpParams, 3000);  
  
    HttpConnectionParams.setSoTimeout(httpParams, 5000);  
    HttpResponse response = client.execute(new HttpGet(url));  
    HttpEntity entity = response.getEntity();  
    if (entity != null) {  
        BufferedReader reader = new BufferedReader(new InputStreamReader(  
                entity.getContent(), "UTF-8"), 8192);  
  
        String line = null;  
        while ((line = reader.readLine()) != null) {  
            sb.append(line + "\n");  
        }  
        reader.close();  
  
    }  
  
    return sb.toString();  
}  
public static HttpResponse post(Map<String, Object> params, String url) {  
  
    HttpClient client = new DefaultHttpClient();  
    HttpPost httpPost = new HttpPost(url);  
    httpPost.addHeader("charset", HTTP.UTF_8);  
    httpPost.setHeader("Content-Type",  
            "application/x-www-form-urlencoded; charset=utf-8");  
    HttpResponse response = null;  
    if (params != null && params.size() > 0) {  
        List<NameValuePair> nameValuepairs = new ArrayList<NameValuePair>();  
        for (String key : params.keySet()) {  
            nameValuepairs.add(new BasicNameValuePair(key, (String) params  
                    .get(key)));  
        }  
        try {  
            httpPost.setEntity(new UrlEncodedFormEntity(nameValuepairs,  
                    HTTP.UTF_8));  
            response = client.execute(httpPost);  
        } catch (UnsupportedEncodingException e) {  
            e.printStackTrace();  
        } catch (ClientProtocolException e) {  
            e.printStackTrace();  
        } catch (IOException e) {  
            e.printStackTrace();  
        } catch (RuntimeException e) {  
            e.printStackTrace();  
        }  
    } else {  
        try {  
            response = client.execute(httpPost);  
        } catch (ClientProtocolException e) {  
            e.printStackTrace();  
        } catch (IOException e) {  
            e.printStackTrace();  
        }  
    }  
  
    return response;  
  
}  
public static Object getValues(Map<String, Object> params, String url) {  
    String token = "";  
    HttpResponse response = post(params, url);  
    if (response != null) {  
        try {  
            token = EntityUtils.toString(response.getEntity());  
            response.removeHeaders("operator");  
        } catch (ParseException e) {  
            e.printStackTrace();  
        } catch (IOException e) {  
            e.printStackTrace();  
        }  
    }  
    return token;  
}  
public static Object setImgByStr(String imgStr,String imgName){  
    String url =  host+"channel-uploadImage.action";  
    Map<String,Object> params = new HashMap<String, Object>();  
    params.put("imgStr", imgStr);  
    params.put("imgName", imgName);  
    return getValues(params, url);  
}  

后台接收数据:

public void uploadPhoto() {  
    //获取存储路径  
    HttpServletRequest request = ServletActionContext.getRequest();  
    String path = ServletActionContext.getServletContext().getRealPath("/")+"upload";  
    File file = new File(path);  
    if(!file.exists()){  
        file.mkdir();  
    }  
    String imgPath  = path + request.getParameter("imgName");  
    String imgStr = request.getParameter("imgStr");  
    boolean flag = string2Image(imgStr, imgPath);  
    JacksonUtil.responseJSON(response, flag);  
}  

后台图片处理:

/** 
 * 通过BASE64Decoder解码,并生成图片 
 * @param imgStr 解码后的string 
 */  
public boolean string2Image(String imgStr, String imgFilePath) {  
    // 对字节数组字符串进行Base64解码并生成图片  
    if (imgStr == null)  
        return false;  
    try {  
        // Base64解码  
        byte[] b = new BASE64Decoder().decodeBuffer(imgStr);  
        for (int i = 0; i < b.length; ++i) {  
            if (b[i] < 0) {  
                // 调整异常数据  
                b[i] += 256;  
            }  
        }  
        // 生成Jpeg图片  
        OutputStream out = new FileOutputStream(imgFilePath);  
        out.write(b);  
        out.flush();  
        out.close();  
        return true;  
    } catch (Exception e) {  
        return false;  
    }  
}     

本文转载自:http://blog.csdn.net/h7870181/article/details/19971557

共有 人打赏支持
ForingY
粉丝 23
博文 272
码字总数 156129
作品 0
杭州
程序员
私信 提问
HTML5视频教程之canvas合成海报所遇问题及解决方案

本篇文章扣丁学堂HTML5培训小编大家分享HTML5开发方面的问题:canvas合成海报所遇问题及解决方案,HTML5不论是现在还是今后的发展相信很多人都是很看好的,下面和小编一起来了解一下HTML5开发...

扣丁学堂
08/29
0
0
android上传图片到服务器(使用base64字节流的形式通过 AsyncHttpClient框架

前端 andoid activity用到的函数 AsyncHttpClient 是一个框架提供的库 可以异步传输,使用时需下载android-async-http-1.4.4.jar包导入到项目中 [java] view plaincopy public static void r...

postdep
2015/02/03
0
2
Google Play 又现恶意软件 谷歌表示 Play Protect 可保护

趋势科技的安全研究人员在 Google Play 中发现了一款使用 Kotlin 编程语言开发的恶意应用程序。 恶意应用程序 Swift Cleaner 伪装成一款用于清理和优化安卓设备的实用程序,安全研究人员在其...

局长
01/11
1K
12
微信浏览器js sdk上传照片在IOS端上传的照片在服务端获取的后缀名不正确

微信浏览器上传文件用原生input type=file multiple 在android手机中无法选择多张照片所以使用微信js sdk来上传照片 因为android和ios返回的base64码有点不同所以加了个头,这样能在页面直接...

非来之来
10/16
42
0
新型银行木马病毒MysteryBot Android深度分析

  近日,国外某安全公司发现一种新型银行木马病毒MySteryBot Android,该病毒为银行木马LokiBot Android的变种,其恶意行为除了利用银行木马窃取金融信息外,还包括恶意监视键盘、植入勒索...

FreeBuf
07/16
0
0

没有更多内容

加载失败,请刷新页面

加载更多

解析Node.js通过axios实现网络请求

本次给大家分享一篇node.js通过axios实现网络请求的方法,写的十分的全面细致,具有一定的参考价值,对此有需要的朋友可以参考学习下。如有不足之处,欢迎批评指正。 1、使用Npm 下载axios n...

前端攻城老湿
7分钟前
0
0
深入浅出之React-redux中connect的装饰器用法@connect

这篇文章主要介绍了react-redux中connect的装饰器用法@connect详解,写的十分的全面细致,具有一定的参考价值,对此有需要的朋友可以参考学习下。如有不足之处,欢迎批评指正。 通常我们需要一...

前端攻城小牛
8分钟前
0
0
详解css BEM书写规范

BEM是基于组件的web开发方法。其思想是将用户界面分隔为独立的块,从而使开发复杂的UI界面变得更简单和快,且不需要粘贴复制便可复用现有代码。BEM由Block、Element、Modifier组成。选择器里...

前端小攻略
24分钟前
2
0
一个centos初始化脚本

概述 就是自己无聊写的一个脚本,欢迎使用,star,fork顺便关注我一波 https://github.com/bboysoulcn/centos 使用方法 这个是给最小化安装的centos使用的,在centos 7.5上测试过,当然其他的...

bboysoulcn
28分钟前
7
0
mybatis 自动维护 createdAt, updatedAt

SpringBoot Mybatis Plus公共字段自动填充功能

youngjdong
31分钟前
6
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部