zoukankan      html  css  js  c++  java
  • Android 关于HttpClient上传中文乱码的解决办法

      使用过HttpClient的人都知道可以通过addTextBody方法来添加要上传的文本信息,但是,如果要上传中文的话,或还有中文名称的文件会出现乱码的问题,解决办法其实很简单:

    第一步:设置MultipartEntityBuilder的编码方式为UTF-8。

    builder.setCharset(Charset.forName(HTTP.UTF_8));//设置请求的编码格式 

    第二步:创建ContentType对象,指定UTF-8编码。

    ContentType contentType= ContentType.create(HTTP.PLAIN_TEXT_TYPE, HTTP.UTF_8); 

    第三步:使用addPart+ StringBody代替addTextBody。如:

    StringBody stringBody=new StringBody("中文乱码",contentType);
    builder.addPart("test",stringBody);

    附上完整代码:

    ContentType contentType = ContentType.create(HTTP.PLAIN_TEXT_TYPE, HTTP.UTF_8);      
    HttpClient client=new DefaultHttpClient();// 开启一个客户端 HTTP 请求 
    HttpPost post = new HttpPost(url);//创建 HTTP POST 请求  
    MultipartEntityBuilder builder = MultipartEntityBuilder.create();
    builder.setCharset(Charset.forName(HTTP.UTF_8));//设置请求的编码格式
    builder.setMode(HttpMultipartMode.BROWSER_COMPATIBLE);//设置浏览器兼容模式
    int count=0;
    for (File file:files) {
    //            FileBody fileBody = new FileBody(file);//把文件转换成流对象FileBody
    //            builder.addPart("file"+count, fileBody);
        builder.addBinaryBody("file"+count, file);
        count++;
    }        
    builder.addTextBody("method", params.get("method"));//设置请求参数
    builder.addTextBody("fileTypes", params.get("fileTypes"));//设置请求参数
    StringBody stringBody=new StringBody("中文乱码",contentType);
    builder.addPart("test", stringBody);
    HttpEntity entity = builder.build();// 生成 HTTP POST 实体      
    post.setEntity(entity);//设置请求参数
    HttpResponse response = client.execute(post);// 发起请求 并返回请求的响应
    if (response.getStatusLine().getStatusCode()==200) {
        return true;
    }
    return false;
  • 相关阅读:
    api.js
    vue开关
    vue 单选框自定义
    vue 笔记
    Flutter 检测网络连接 监听网络变化
    lutter 调用原生硬件 Api 实现扫码
    flutter 支付宝支付流程以及用 Flutter 在 Android Ios 中实现支付宝支付
    js+css 动效+1的效果
    Vue -- filters 过滤器、倒计时效果
    移动端如何实现两行点点点?
  • 原文地址:https://www.cnblogs.com/zhujiabin/p/5715064.html
Copyright © 2011-2022 走看看