Okhttp3 post上传文件的时候携带文件的参数怎么做啊 下面是接口文档和练习的demo求教!谢谢

public class OkhttpActivity extends AppCompatActivity implements View.OnClickListener {

private Button buttonget, button_post, button_getparams, button_posttparams, button_postfile;

private TextView text;

private static final String TAG = "OriginNetWorkActivity";

private static final String URL = "http://api.nongfucang.cn/home/apitest/member_upload_img";

private static final String Token = "4tFZb5UUk5N8GLCYU3aeselQLFRNQEOlyUL9p6uaBHIHTL6dfG";

private RxPermissions rxPermissions;

@Override

protected void onCreate(@Nullable Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_okhttp);

init();

}

public void init() {

buttonget = findViewById(R.id.button);

button_post = findViewById(R.id.button_post);

button_posttparams = findViewById(R.id.button_posttparams);

text = findViewById(R.id.text);

button_getparams = findViewById(R.id.button_getparams);

button_postfile = findViewById(R.id.button_postfile);

button_getparams.setOnClickListener(this);

buttonget.setOnClickListener(this);

button_post.setOnClickListener(this);

button_posttparams.setOnClickListener(this);

button_postfile.setOnClickListener(this);

rxPermissions = new RxPermissions(this);

rxPermissions

.request(Manifest.permission.CAMERA, Manifest.permission.WRITE_EXTERNAL_STORAGE, Manifest.permission.READ_EXTERNAL_STORAGE)

.subscribe(granted -> {

if (granted) {

} else {

Toast.makeText(this, "有权限未通过无法开启", Toast.LENGTH_SHORT).show();

}

});

}

@Override

public void onClick(View v) {

switch (v.getId()) {

case R.id.button:

getData();

break;

case R.id.button_post:

postData();

break;

case R.id.button_getparams:

break;

case R.id.button_posttparams:

HashMap params = new HashMap<>();

params.put("token", Token);

File file = new File("/storage/emulated/0/Android/data/com.nfc.shop/cache/1581842329846.jpg");

File[] files = new File[]{file};

String[] name = new String[]{"image"};

postFile(URL, files, name, params);

break;

case R.id.button_postfile:

break;

}

}

private void postFile(String url, File[] files, String[] fileKeys, Map params) {

if (params == null) {

params = new HashMap<>();

}

OkHttpClient okHttpClient = new OkHttpClient.Builder()

.connectTimeout(10000, TimeUnit.SECONDS)

.build();

FormBody.Builder builder = new FormBody.Builder();

for (Map.Entry map : params.entrySet()) {

String key = map.getKey();

String value;

/**

* 判断值是否是空的

*/

if (map.getValue() == null) {

value = "";

} else {

value = map.getValue();

}

/**

* 把key和value添加到formbody中

*/

builder.add(key, value);

}

RequestBody requestBody = builder.build();

MultipartBody.Builder multipartBody = new MultipartBody.Builder();

multipartBody.setType(MultipartBody.ALTERNATIVE)

.addPart(requestBody);

if (files != null) {

RequestBody fileBody = null;

for (int i = 0; i < files.length; i++) {

File file = files[i];

String fileName = file.getName();

fileBody = RequestBody.create(MediaType.parse("image/*"), file);

//TODO 根据文件名设置contentType

multipartBody.addPart(Headers.of("Content-Disposition",

"form-data; name=\"" + fileKeys[i] + "\"; filename=\"" + fileName + "\""),

fileBody);

}

Request request = new Request.Builder()

.url(url)

.post(multipartBody.build())

.build();

Call call = okHttpClient.newCall(request);

call.enqueue(new Callback() {

@Override

public void onFailure(Call call, IOException e) {

}

@Override

public void onResponse(Call call, Response response) throws IOException {

ResponseBody body = response.body();

assert body != null;

String s = body.string();

setText(s);

}

});

}

// OkHttpClient okHttpClient = new OkHttpClient.Builder()

// .connectTimeout(10000, TimeUnit.SECONDS)

// .build();

// File file = new File("/storage/sdcard0/Pictures/1577331681917.jpg");

// MediaType type = MediaType.parse("image/jpeg");

// RequestBody Body = RequestBody.create(file, type);

// RequestBody requestBody = new MultipartBody.Builder()

// .addFormDataPart("File", file.getName(), Body)

// .build();

// Request request = new Request.Builder()

// .post(requestBody)

// .url()

// .build();

// Call call = okHttpClient.newCall(request);

// call.enqueue(new Callback() {

// @Override

// public void onFailure(Call call, IOException e) {

//

// }

//

// @Override

// public void onResponse(Call call, Response response) throws IOException {

//

// }

// });

}

private String guessMimeType(String fileName) {

FileNameMap fileNameMap = URLConnection.getFileNameMap();

String contentTypeFor = fileNameMap.getContentTypeFor(fileName);

if (contentTypeFor == null) {

contentTypeFor = "application/octet-stream";

}

return contentTypeFor;

}

private void postData() {

OkHttpClient okHttpClient = new OkHttpClient.Builder()

.connectTimeout(1000, TimeUnit.SECONDS)

.build();

Map params = new HashMap<>();

params.put("goodsId", "9649");

FormBody.Builder builder = new FormBody.Builder();

// Set> entries = params.entrySet();

// for (Map.Entry entry : entries) {

// String key = entry.getKey();

// String value;

// if(entry.getValue()== null){

// value = "";

// }else{

// value = entry.getValue();

// }

// builder.add(key,value);

// }

for (Map.Entry map : params.entrySet()) {

String key = map.getKey();

String value;

/**

* 判断值是否是空的

*/

if (map.getValue() == null) {

value = "";

} else {

value = map.getValue();

}

/**

* 把key和value添加到formbody中

*/

builder.add(key, value);

}

RequestBody requestBody = builder.build();

Request request = new Request.Builder()

.post(requestBody)

.url("https://www.sunofbeach.net/shop/api/goods/relative")

.build();

Call call = okHttpClient.newCall(request);

call.enqueue(new Callback() {

@Override

public void onFailure(Call call, IOException e) {

}

@Override

public void onResponse(Call call, Response response) throws IOException {

if (response.code() == 200) {

ResponseBody body = response.body();

assert body != null;

String s = body.string();

setText(s);

}

}

});

}

private void getData() {

OkHttpClient okHttpClient = new OkHttpClient.Builder()

.connectTimeout(10000, TimeUnit.SECONDS)

.build();

Request request = new Request.Builder()

.get()

.url("https://www.sunofbeach.net/shop/api/discovery/categories")

.build();

Call call = okHttpClient.newCall(request);

call.enqueue(new Callback() {

@Override

public void onFailure(Call call, IOException e) {

}

@Override

public void onResponse(Call call, Response response) throws IOException {

if (response.code() == 200) {

ResponseBody body = response.body();

assert body != null;

String s = body.string();

setText(s);

}

}

});

}

public void setText(final String s) {

runOnUiThread(new Runnable() {

@Override

public void run() {

text.setText(s);

}

});

}

}

Charles抓包的结果是

{

"code": 201,

"msg": "token 不能为空"

}

okhttp上传图片和其他参数_阳光沙滩-Okhttp3 post上传文件的时候携带文件的参数的问题...相关推荐

  1. php上传图片限制类型,php,_使用php的图片上传类进行图片上传,总是提示:上传文件时出错 : 未允许类型 。都是默认的配置,php - phpStudy...

    使用php的图片上传类进行图片上传,总是提示:上传文件时出错 : 未允许类型 .都是默认的配置 使用php的图片上传类进行图片上传,总是提示:上传文件时出错 : 未允许类型 .都是默认的配置 $upl ...

  2. ios 上传图片失败 小程序_微信小程序图片上传时,iOS端第一次上传必定失败,nignx返回400,短时间内再次上传可以成功。 而安卓端完美运行。...

    自己分析: 1 是小程序本身兼容有问题. 2 是nginx配置问题. 已经逛过小程序官方社区,看到有几个人遇到跟我一样的问题,但都没有被详细答复.我也详细描述了一下自己的问题. https://dev ...

  3. vue获取上传图片的名字和路径_使用Vue实现图片上传的三种方式

    项目中需要上传图片可谓是经常遇到的需求,本文将介绍 3 种不同的图片上传方式,在这总结分享一下,有什么建议或者意见,请大家踊跃提出来. 没有业务场景的功能都是耍流氓,那么我们先来模拟一个需要实现的业务 ...

  4. python实现文件上传和下载_[Python] socket实现TFTP上传和下载

    一.说明 本文主要基于socket实现TFTP文件上传与下载. 测试环境:Win10/Python3.5/tftpd64. tftpd下载:根据自己的环境选择下载,地址 :http://tftpd32 ...

  5. 腾讯视频下载安装免费装到手机_腾讯视频怎么上传个人本地视频

    不管这个腾讯视频好用与否,都有一大批用户,本文播放器家园网小编分享腾讯视频下载安装免费装到手机_腾讯视频怎么上传个人本地视频.VIP会员频道聚合海量VIP品质内容,连续签到解锁惊喜奖励.摇一摇抽VIP ...

  6. ajax上传 java_使用Ajax进行文件与其他参数的上传功能(java开发)

    文件上传: 记得前一段时间,为了研究Ajax文件上传,找了很多资料,在网上看到的大部分是form表单的方式提交文件,对于Ajax方式提交文件并且也要提交表单中其他数据,发现提及的并不是很多,后来在同事 ...

  7. el-upload 组件在 on-success 文件上传成功的钩子中传递更多参数

    el-upload 组件在 on-success 文件上传成功的钩子中传递更多参数 <el-table-columnlabel="附件"align="center& ...

  8. okhttp上传图片和其他参数_Android中Okhttp3实现上传多张图片同时传递参数_放手_前端开发者...

    之前上传图片都是直接将图片转化为io流传给服务器,没有用框架传图片. 最近做项目,打算换个方法上传图片. Android发展到现在,Okhttp显得越来越重要,所以,这次我选择用Okhttp上传图片. ...

  9. bootstrapinput传参数_***文件上传控件bootstrap-fileinput的使用和参数配置说明

    特别注意: 引入所需文件后页面刷新查看样式奇怪,浏览器提示错误等,可能是因为js.css文件的引用顺序问题,zh.js需要在fileinput.js后面引入.bootstrap最好在fileinput ...

最新文章

  1. 应用程序 mysql 连接_学生信息管理系统之四:实现应用程序与数据库的连接
  2. 11.28 限定某个目录禁止解析php 11.29 限制user_agent 11.30/11.31 php相关配置
  3. Session的底层实现原理
  4. Linux 修改主机名 和 ip 映射关系
  5. OBS鉴权实现的宝典秘籍,速拿!
  6. vb中空操作(等待)的指令、延时方法
  7. php创建目录规则,php创建目录功能
  8. 极客时间_算法训练营(代码实现汇总)
  9. 呼吸运动减肥法-可以加快新陈代谢
  10. Qt中可执行文件如何添加ICON图标
  11. 踩坑记6 vue3、生命周期钩子、vue-devtools beta
  12. Linux配置本地yum源(光盘镜像挂载)
  13. android 画布清屏,html5清空画布方法(三种)
  14. FTP显示文件的修改时间与实际时间不一致
  15. hmailserver + afterlogic 搭建webmail
  16. 【办公Tips】 如何快速将一列Excel值变成一段用符号间隔的文字
  17. Xadmin-Xadmin的安装与配置(Django2.0+python3.6)
  18. linux文件属性详细说明(网络转载,仅供学习之用)
  19. 华硕B85M-V PLUS 刷NVME协议BIOS
  20. 基于ASP.NET的蒙古文网站建立及若干问题分析

热门文章

  1. 黑马培训有python吗
  2. 【前端】CSS(十一)PC端品优购项目(下)
  3. 重新连接网络后怎么设置计算机,路由器恢复出厂设置后怎么重新设置?
  4. 录屏软件bandicam
  5. 东方马达步进电机AZM66AK-HS100+AZD-KD调试经验记录
  6. linux 制作iso 和 刻录DVD
  7. node.js实现图片上传
  8. 出现Cannot refer to the non-final local variable guoDeGang defined in an enclosing scope
  9. ssd nvme sata_NVMe SSD与传统SATA SSD
  10. 怀揣感恩之心,学会感恩