资讯专栏INFORMATION COLUMN

多图片上传Android,服务器端实现

liujs / 1795人阅读

摘要:最近时间在做的项目中需要用到前端上传服务器第一次做文件上传的服务器端查了各种资料踩了各种坑记录一下最终的实现方式一服务器端服务器端使用的是框架文件实现逻辑获取用户上传的文件将文件保存到文件夹保存成功后将文件的索引存入数据库获取用户上传的文件

</>复制代码

  1. 最近时间在做的项目中需要用到Android前端上传服务器,第一次做文件上传的服务器端,查了各种资料,踩了各种坑,记录一下最终的实现方式
  2. **一.服务器端**
  3. 服务器端使用的是ssh框架,文件实现逻辑:
  4. 1.获取用户上传的文件
  5. 2.将文件保存到文件夹
  6. 3.保存成功后将文件的索引存入数据库,
  7. 1.获取用户上传的文件
  8. 完整action如下:

</>复制代码

  1. public class UploadAction extends ActionSupport implements ModelDriven, ServletResponseAware, ServletRequestAware {
  2. private HttpServletResponse response;
  3. private HttpServletRequest request;
  4. //*********重点******
  5. // 多文件上传的文件key,相当于获取 request.getParameter(key)
  6. //如果传入的key不对,上传的文件为空,报空指针异常,
  7. private List file;
  8. private List fileFileName;
  9. private List fileContentType;
  10. private List dataUrl;
  11. public void setDataUrl(List dataUrl) {
  12. this.dataUrl = dataUrl;
  13. }
  14. public List getFile() {
  15. return file;
  16. }
  17. public void setFile(List file) {
  18. this.file = file;
  19. }
  20. public List getFileFileName() {
  21. return fileFileName;
  22. }
  23. public void setFileFileName(List fileFileName) {
  24. this.fileFileName = fileFileName;
  25. }
  26. public List getFileContentType() {
  27. return fileContentType;
  28. }
  29. public void setFileContentType(List fileContentType) {
  30. this.fileContentType = fileContentType;
  31. }
  32. private QualityBean bean = new QualityBean();
  33. public void setBean(QualityBean bean) {
  34. this.bean = bean;
  35. }
  36. public String upload() throws Exception {
  37. dataUrl = new ArrayList();
  38. String imgpath = "D:/loadtest";
  39. System.out.println("file-size" + file.size());
  40. if (file != null) {
  41. for (int i = 0; i < file.size(); ++i) {
  42. InputStream is = new FileInputStream(file.get(i));
  43. dataUrl.add(imgpath + this.getFileFileName().get(i));
  44. File destFile = new File(imgpath, this.getFileFileName().get(i));
  45. OutputStream os = new FileOutputStream(destFile);
  46. byte[] buffer = new byte[400];
  47. int length = 0;
  48. while ((length = is.read(buffer)) > 0) {
  49. os.write(buffer, 0, length);
  50. }
  51. is.close();
  52. os.close();
  53. //往数据库添加--略
  54. //返回数据,真实项目中返回自己逻辑判断
  55. BooleanBean bean = new BooleanBean();
  56. bean.setUpdate(true);
  57. DataUtils.writeBeanDate(response, bean);
  58. }
  59. }
  60. return null;
  61. }
  62. @Override
  63. public void setServletRequest(HttpServletRequest httpServletRequest) {
  64. this.request = httpServletRequest;
  65. }
  66. @Override
  67. public void setServletResponse(HttpServletResponse httpServletResponse) {
  68. this.response = httpServletResponse;
  69. }
  70. @Override
  71. public QualityBean getModel() {
  72. return bean;
  73. }
  74. }

structs.xml配置如下

</>复制代码

  1. upload
  2. 104857600

如果报错如下,则是上传文件超过设置的大小,

</>复制代码

  1. **二.Android 端代码实现**

</>复制代码

  1. final List list = new ArrayList<>();
  2. list.add("/storage/emulated/0/Boohee/1565153408424.jpg");
  3. list.add("/storage/emulated/0/Boohee/1564797245581.jpg");
  4. submit.setOnClickListener(new View.OnClickListener() {
  5. @Override
  6. public void onClick(View view) {
  7. Map params = new HashMap<>();
  8. RequestBody pictureNameBody = RequestBody.create(MediaType.parse("multipart/form-data"), "file");
  9. for (String str : list) {
  10. File picture = new File(str);
  11. RequestBody requestFile = RequestBody.create(MediaType.parse("multipart/form-data"), picture);
  12. params.put("file"; filename="" + picture.getName() + "", requestFile);
  13. }
  14. mvpPresenter.submit("韶关1店",pictureNameBody, params);
  15. }
  16. });

上面file作为文件上传的key,两端必须保持一致

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/75987.html

相关文章

  • 精彩文章大合集- 收藏集 - 掘金

    摘要:发布应用市场的平台抢红包工具红包精灵开源啦掘金红包精灵,如果喜欢,点个开源不易。作者将原素材文章进行了新内容的添加和重新排列,但是因为文章高效的代码编写技巧总结前端掘金本文总结了代码编写技巧,来提升你的和代码。 收藏安卓开发中非常实用优秀的库! 有图有真相! - Android - 掘金本来是打算收藏工具类的,但转念一想,已经有这么多优秀的库了,就没必要再去重复造轮子了,便归纳工作中比...

    ermaoL 评论0 收藏0
  • 移动上传图片翻转的解决方案

    摘要:后续过了几天,公司购置了几台全新的测试机,测试同学将系统在一台三星的机子上一测,又发现新问题了选择完图片进行本地预览时,发现图片翻转了但上传后再展示又是正常的。 最近在处理移动端选择图片实时预览并上传时遇到一个问题:上传前图片预览正常,但上传到服务器上的图片展示到页面上时,有时会出现图片翻转的问题,一般是翻转 90 度。后经一翻研究找到了问题所在,特在此记录一下。 问题描述 接上面提到...

    shinezejian 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<