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条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Windows10,CentOS7,CentOS8安装Nodejs环境
- Docker安装Oracle12C,快速搭建Oracle学习环境
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- CentOS8编译安装MySQL8.0.19
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS8安装Docker,最新的服务器搭配容器使用
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- SpringBoot2整合Redis,开启缓存,提高访问速度
- CentOS7,8上快速安装Gitea,搭建Git服务器
- Docker使用Oracle官方镜像安装(12C,18C,19C)