Android图文上传
这次介绍下如何使用Retrofit+rxjava上传图片和文字
接口的写法
public interface MarketApiService {
@Multipart//这里一定要加这个
@POST("market/addNewOrder")
Observable<ResultBean> addNewOrder(@QueryMap Map<String, String> map, @Part MultipartBody.Part pic);
}
上传的代码
Map<String, String> params = new HashMap<String, String>();
params.put("ship_type_id", type);
params.put("cons_number", consNumber);
params.put("note", beizhu);
File fileByUri = FileUtil.getFileByUri(imagepath, this);
//这里最好写成MediaType.parse("image/*"),之前写成MediaType.parse("image/png")上传失败
RequestBody photoRequestBody = RequestBody.create(MediaType.parse("image/*"), fileByUri);
MultipartBody.Part photo = MultipartBody.Part.createFormData("file", fileByUri.getName(), photoRequestBody);
RetrofitUtils.getInstance().getApiServier(MarketApiService.class)
.addNewOrder(params,photo)
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Consumer<ResultBean>() {
@Override
public void accept(ResultBean resultBean) throws Exception {
}
}, new Consumer<Throwable>() {
@Override
public void accept(Throwable throwable) throws Exception {
}
});
这里的图片选择器使用的是知乎的图片选择器https://github.com/zhihu/Matisse
另外这里还有将Uri转换为File的工具类(因为知乎图片选择器返回的是Uri)
public static File getFileByUri(Uri uri, Context context) {
String path = null;
if ("file".equals(uri.getScheme())) {
path = uri.getEncodedPath();
if (path != null) {
path = Uri.decode(path);
ContentResolver cr = context.getContentResolver();
StringBuffer buff = new StringBuffer();
buff.append("(").append(MediaStore.Images.ImageColumns.DATA).append("=").append("'" + path + "'").append(")");
Cursor cur = cr.query(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, new String[] { MediaStore.Images.ImageColumns._ID, MediaStore.Images.ImageColumns.DATA }, buff.toString(), null, null);
int index = 0;
int dataIdx = 0;
for (cur.moveToFirst(); !cur.isAfterLast(); cur.moveToNext()) {
index = cur.getColumnIndex(MediaStore.Images.ImageColumns._ID);
index = cur.getInt(index);
dataIdx = cur.getColumnIndex(MediaStore.Images.ImageColumns.DATA);
path = cur.getString(dataIdx);
}
cur.close();
if (index == 0) {
} else {
Uri u = Uri.parse("content://media/external/images/media/" + index);
System.out.println("temp uri is :" + u);
}
}
if (path != null) {
return new File(path);
}
} else if ("content".equals(uri.getScheme())) {
// 4.2.2以后
String[] proj = { MediaStore.Images.Media.DATA };
Cursor cursor = context.getContentResolver().query(uri, proj, null, null, null);
if (cursor.moveToFirst()) {
int columnIndex = cursor.getColumnIndexOrThrow(MediaStore.Images.Media.DATA);
path = cursor.getString(columnIndex);
}
cursor.close();
return new File(path);
} else {
//Log.i(TAG, "Uri Scheme:" + uri.getScheme());
}
return null;
}
个人博客https://myml666.github.io/
关注公众号
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
-
上一篇
Android签名包apk安装不上:INSTALL_PARSE_FAILED_NO_CERTIFICATES
Android apk安装不上:INSTALL_PARSE_FAILED_NO_CERTIFICATES Android studio正式打包生成签名的apk,在一些低版本Android系统的手机上安装不上,输出错误提示:INSTALL_PARSE_FAILED_NO_CERTIFICATES 解决方案,在Android studio打包过程中,生成签名包时候,Signature versions的V1和V2都勾选:
-
下一篇
Android音频管理之AudioManager(原创)
本文已独家授权 郭霖 ( guolin_blog) 公众号发布! 本篇文章主要介绍的是Android应用(WebView加载H5的音频管理只是其中的一种)如何有效管理或定制音频的基本内容和一些思路。 事情的起因是这样的,最近接到个需求WebView加载H5游戏,嗯,霹雳巴拉一顿猛敲基本上就搞定了,针对8.1系统也做了一些适配。好了,验货的时间到了,产品用他那傲娇的手指一顿操作后不耐烦的说,这个应用为什么按下HOME键后(Back键禁用了 - - !)游戏还有声音???当时我在想,目标Activity生命周期 onResume()和onPause()不是写了对应的 myWebView.onResume();以及 myWebView.onPause()的啊啊!难不成那厮又在戏剧性耍我? 带着黑人小哥头上3个问号表情的我说到,按下HOME键没有声音的嘛,我先试试。产品瞬间反转谄媚一笑说到,下午可以搞定嘛?我说,这个声音可能是H5游戏引擎技术的问题,我先看下什么问题。然后,就是老套路编译代码打开应用插上耳机,进入游戏BGM时间,按下HOME键,MMP,声音真没消失!!! 好了,遇到问题后我跟大...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- MySQL数据库中FOR UPDATE的使用
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- MySQL数据库在高并发下的优化方案
- CentOS关闭SELinux安全模块
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS6,CentOS7官方镜像安装Oracle11G
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- MySQL8.0.19开启GTID主从同步CentOS8

微信收款码
支付宝收款码