iis服务器助手广告广告
返回顶部
首页 > 资讯 > 服务器 >layui如何上传图片到服务器的非项目目录下
  • 537
分享到

layui如何上传图片到服务器的非项目目录下

2024-04-02 19:04:59 537人浏览 安东尼
摘要

小编给大家分享一下layui如何上传图片到服务器的非项目目录下,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!1、layui没办法与fORM表单中的其他字段一同提交到后台,所以只能通过先提交

小编给大家分享一下layui如何上传图片到服务器的非项目目录下,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

1、layui没办法与fORM表单中的其他字段一同提交到后台,所以只能通过先提交图片,然后通过返回的图片的值来提交到数据库

2、先将所需要的jar包导入,我是用的Maven所以,需要在父pom.xml文件中添加下面两个jar包(版本自己选择)

<dependency>
  <groupId>commons-fileupload</groupId>
  <artifactId>commons-fileupload</artifactId>
  <version>1.3.1</version>
</dependency>
<dependency>
  <groupId>commons-io</groupId>
  <artifactId>commons-io</artifactId>
  <version>2.4</version>
</dependency>

3、然后编写前台页面

如果只需要上传一张图片可以看上传loGo的步骤,多张的话可以看上传图片的步骤

<div>
  <label class="layui-form-label">logo</label>
  <div class="layui-input-block">
    <button type="button" class="layui-btn" id="uploadLogo">
      <i class="layui-icon">&#xe67c;</i>选择logo
    </button>
    <div class="layui-upload-list">
      <!-- 为了回显 -->
      <img class="layui-upload-img" id="upload-logo" width="150px" src="${educationalType.edLogo}">
    </div>
    <button type="button" class="layui-btn" id="submit_logo">开始上传
    </button>
    <input id="logoText" name="edLogo" type="hidden" />
  </div>
</div>
<div>
  <label class="layui-form-label">图片</label>
  <div class="layui-input-block">
    <button type="button" class="layui-btn" id="uploadImage">
      <i class="layui-icon">&#xe67c;</i>选择图片
    </button>
    <div class="layui-upload-list" id="imageView">
      <c:if test="${pageFlag == 'updatePage' and educationalType.edImage1 != null}">
        <img class="layui-upload-img" id="upload-image1" width="150px" src="${educationalType.edImage1}" >
      </c:if>
      <c:if test="${pageFlag == 'updatePage' and educationalType.edImage2 != null}">
        <img class="layui-upload-img" id="upload-image2" width="150px" src="${educationalType.edImage2}">
      </c:if>
    </div>
    <button type="button" class="layui-btn" id="submit_image">开始上传</button>
    <input id="imageText" name="edImage" type="hidden" />
  </div>
</div>

上图中input和img的目的是为了可以接收返回值,从而在提交时可以将图片信息上传到后台

<script type="text/javascript">

  //上传logo
  layui.use('upload', function(){
    var $ = layui.Jquery,
    upload = layui.upload;

    //选完文件后不自动上传
    upload.render({
      elem: '#uploadLogo',
      url: '${ctx}/upload/uploadLogoToServer.do',
      auto: false,
      //multiple: true,
      choose: function(obj){
        console.log(obj)
        //预读本地文件示例,不支持ie8
        obj.preview(function(index, file, result){
          $('#upload-logo').attr('src', result); //图片链接(base64)
          $("#img_url").attr('value',result);
        });
      },
      bindAction: '#submit_logo',
      done: function(res){
        $("#logoText").attr('value',res.url);
        console.log(res)
        return layer.msg(res.msg,{icon: res.status,time: 2000});
      }
    });

  //上传图片
    var fileCount = 0;//控制文件数量
    var maxFileCount = 2;//文件上传最大数量,如果没有限制上传文件的数量则不需要
    var maxFileSize = 20;//文件上传最大大小
    var resultValue = 0;
    var url = "";
    upload.render({
      elem: '#uploadImage',
      url: '${ctx}/upload/uploadImageToServer.do',
      auto: false,
      //multiple: true,
      choose: function(obj){
        var files = this.files = obj.pushFile(); //将每次选择的文件追加到文件队列
        //layer.load();
        console.log(obj)
        //预读本地文件示例,不支持ie8
        obj.preview(function(index, file, result){
          fileCount++;
          if(fileCount>maxFileCount){
            fileCount = maxFileCount;
            layer.msg('文件数量不得超过'+maxFileCount+'个',{icon:2});
            return;
          }
          //在当前ID为“imageView”的区域显示图片
          $('#imageView').append('<img name = "edImage" ' +
            ' ' +
            'src="'+ result +'" alt="'+ file.name +'" class="layui-upload-img">')
        });
      },
      bindAction: '#submit_image',
      done: function(res){
        if(resultValue < 2){
          url = url + res.url + ",";
        }
        if(resultValue == 1){
          $("#imageText").attr('value',url);
        }
        resultValue++;
        console.log(res)
        return layer.msg(res.msg,{icon: res.status,time: 2000});
      }
    });
  });
</script>

4、因为layui在上传多张图片的时候是通过多次请求传递过去,所以是数据是一条一条的接收的,如果你需要回显,那么就需要在后台进行拼接,不拼接很可能会出现只传返回一张图片的信息

UploadCollect

@RequestMapping(value = "/uploadImageToServer.do")
@ResponseBody
public ResultMsg insertImageToEducational(@RequestParam(value = "file")MultipartFile[] files) throws Exception {
  ResultMsg msg = new ResultMsg();
  String url = "";
  for (int i=0,length = files.length; i < length; i++) {
    if(files[i] != null && !files[i].isEmpty()) {
      //获取路径,路径我写的是固定路径,直接映射到服务器根目录下的/usr/Images/logo
      String upload_path = IMAGE_ROOT_URL;
      String upload_fileName = FileUpload.uploadFile(files[i], upload_path);
      msg.setStatus(0);
      url = url + upload_fileName;
    }else {
      msg.setStatus(1);
      msg.setMsg("上传失败");
      msg.setUrl("给一个失败的图片路径");
      return msg;
    }
  }
  msg.setStatus(1);
  msg.setMsg("上传成功");
  msg.setUrl(url);
  return msg;

}

FileUpload

public static String uploadFile(MultipartFile multipartFile, String path) throws Exception {
  File file = new File(path);
  if (!file.exists()) {
    file.mkdirs();
  }
  FileInputStream fileInputStream = (FileInputStream) multipartFile.getInputStream();
  String fileName = UUID.randomUUID() + multipartFile.getOriginalFilename();
  BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(path + File.separator + fileName));
  byte[] bs = new byte[1024];
  int len;
  while ((len = fileInputStream.read(bs)) != -1) {
    bos.write(bs, 0, len);
  }
  bos.flush();
  bos.close();
  return fileName;
}

5、这就是图片上传的步骤

看完了这篇文章,相信你对“layui如何上传图片到服务器的非项目目录下”有了一定的了解,如果想了解更多相关知识,欢迎关注编程网服务器频道,感谢各位的阅读!

--结束END--

本文标题: layui如何上传图片到服务器的非项目目录下

本文链接: https://www.lsjlt.com/news/75322.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • layui如何上传图片到服务器的非项目目录下
    小编给大家分享一下layui如何上传图片到服务器的非项目目录下,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!1、layui没办法与form表单中的其他字段一同提交到后台,所以只能通过先提交...
    99+
    2024-04-02
  • vue项目中如何使用axios上传图片
    这篇文章将为大家详细讲解有关vue项目中如何使用axios上传图片,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。axios 简介axios 是一个基于Promise 用于...
    99+
    2024-04-02
  • 如何把目录下的项目提交到gitlab
    Gitlab是一款非常流行的代码托管平台,它可以帮助开发者管理代码、协作开发和跟踪代码的变更历史等。在使用Gitlab进行团队协作开发时,如何把目录下的项目提交到Gitlab是非常重要的一步。那么下面,我们就来详细介绍一下在Gitlab上如...
    99+
    2023-10-22
  • 如何将自己的项目上传到Github
    GitHub是一种基于Git的代码托管平台,是目前全球最大的开源社区之一。在GitHub上可以共享和发现代码、与其他开发人员交流,对于开源软件和组织、公司和个人开发者来说,它都是一个理想的平台。于是很多开发者会把自己的项目上传到GitHub...
    99+
    2023-10-22
  • 如何部署项目到云服务器上
    要将项目部署到云服务器上,可以按照以下步骤进行操作:1. 选择云服务提供商:根据项目需求和预算,选择适合的云服务提供商。2. 创建云...
    99+
    2023-09-16
    云服务器
  • 如何使用批处理上传文件到ftp目录下
    小编给大家分享一下如何使用批处理上传文件到ftp目录下,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!为了快速将项目中开发的补丁程序通过ftp快速上传到linux下...
    99+
    2023-06-08
  • 如何把java项目部署到服务器上
    要将Java项目部署到服务器上,可以按照以下步骤进行操作: 将Java项目打包成war文件或jar文件。可以使用Maven或Gr...
    99+
    2024-04-09
    java 服务器
  • 如何部署SpringBoot项目到云服务器上
    这篇文章主要介绍“如何部署SpringBoot项目到云服务器上”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“如何部署SpringBoot项目到云服务器上”文章能帮助大家解决问题。一、设置 Maven...
    99+
    2023-07-06
  • gitlab如何上传到一个项目的分支中
    GitLab是一个非常强大的代码协作平台,它可以帮助团队协调工作,管理项目,版本控制等等。在使用GitLab时,我们经常需要将代码上传到特定项目的分支中。本文将介绍如何将代码上传到GitLab上的项目分支中。步骤一:克隆GitLab项目在上...
    99+
    2023-10-22
  • 如何把php项目部署到云服务器上
    在linux系统云服务器中部署php项目的方法首先,远程登录云服务器,进入云服务器操作界面;在linux系统中使用命令:yum install php php-devel 安装php;安装完成后,需使用命令:yum install php-...
    99+
    2024-04-02
  • 如何在Java项目中实现一个简单的图片上传功能
    如何在Java项目中实现一个简单的图片上传功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。具体如下:import java.io.*;import java....
    99+
    2023-05-31
    java ava 目中
  • js实现上传图片到服务器的
    这篇文章主要介绍了js实现上传图片到服务器的,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。具体内容如下HTML//多张图片上传multiple<input t...
    99+
    2023-06-14
  • 如何解决springboot项目找不到resources目录下的资源问题
    小编给大家分享一下如何解决springboot项目找不到resources目录下的资源问题,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!springboot项目找不到resources目录下的资源问题描述:将老的mvc项目...
    99+
    2023-06-20
  • 浅谈如何把Node项目部署到服务器上
    目录1. 如何合理选购一台服务器1.1. 服务器位置的选择;1.2. 服务器镜像的选择;1.3. 服务器系统盘存储的选择;1.4. 服务器带宽选择;1.5. 服务器规格选择;2. 如...
    99+
    2023-02-01
    Node项目部署到服务器 Node项目部署
  • gitee如何创建项目并部署到服务器上
    这篇文章主要介绍“gitee如何创建项目并部署到服务器上”,在日常操作中,相信很多人在gitee如何创建项目并部署到服务器上问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”gitee如何创建项目并部署到服务器上...
    99+
    2023-07-05
  • 如何将php项目部署到本地服务器上
    PHP 是一种广泛使用的服务器端脚本语言,通常用于创建动态网页和应用程序。在您开始开发 PHP 项目之前,您将需要从您的 PHP 编辑器或 IDE 中导出文件并将其部署到本地服务器上。在本文中,我们将解释什么是本地服务器及如何将 PHP 文...
    99+
    2023-05-14
    php
  • GoLand一键上传项目到远程服务器的方法步骤
    我们开发项目常常将项目上传到linux远程服务器上来运行,查看日志等等,每次连接终端输入命令上传文件总是很烦,最近正好在学go开发项目,用到了goland,整理一下我的配置的步骤分享...
    99+
    2024-04-02
  • 如何删除云服务器上的项目
    删除云服务器上的项目可以通过以下步骤进行操作:1. 登录云服务器:使用SSH等工具登录到云服务器。2. 停止项目:如果项目正在运行,...
    99+
    2023-08-29
    云服务器
  • django项目如何部署到服务器
    部署Django项目到服务器通常需要以下步骤: 在服务器上安装Python和Django:首先确保服务器上已安装Python和D...
    99+
    2024-05-08
    django
  • 项目如何放在云服务器上
    将项目放在云服务器上可以通过以下步骤完成:1. 选择云服务提供商:根据项目需求和预算选择合适的云服务提供商。2. 创建云服务器实例:...
    99+
    2023-09-11
    云服务器
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作