注意:只可用于数据量较小的项目,数据量庞大的项目不要用这个,否则会造成图片数量庞大,至服务器运行速度变慢或瘫痪

  HTML代码

//前端使用的是layui框架
<div class="layui-form-item">
<div class="layui-input-block">
    <!-- 上传按钮 -->
<button type="button" class="layui-btn" id="uploadPic"><i class="layui-icon"></i>选择图片</button>
<button type="button" class="layui-btn layui-btn-warm" id="uploadPicBtn">开始上传</button>
    <!-- 隐藏的input,一个隐藏的input(用于保存文件url) -->
    <input type="hidden" id="img_url" name="img" value=""/>
    <!-- 预览区域 -->
<div class="layui-upload-list">
      <img class="layui-upload-img" width="100px" height="80px" id="preShow"/>
      <p id="demoText"></p>
</div>
</div>
</div>

  JS代码

//上传图片
var uploadInst = upload.render({
elem: '#uploadPic' //绑定元素
, url: '/uploadFile' //上传接口 [[@{/upload/img}]]
, auto: false
, exts: 'doc|docx|pdf|jpg|jpeg|png|zip|'//图片格式
, bindAction: '#uploadPicBtn'//点击选择图片,会弹出window弹窗
,size:50 //文件上传的大小,一定要设置
, before: function (obj) {
//预读本地文件示例,不支持ie8
obj.preview(function (index, file, result) {
$('#preShow').attr('src', result); //图片链接(base64)
});
}
, done: function (res) {
//上传失败
if (res.code > 0) {
return layer.msg('上传失败');
}
//上传成功
if (res.code == 0) {
$('#aftershow').attr('src', "/uploadFile/" + res.data);
document.getElementById("img_url").value = res.data;
return layer.msg('上传成功');
}

}
, error: function (re) {
var demoText = $('#demoText');
demoText.html('<span style="color: #FF5722;">上传失败</span> <a class="layui-btn layui-btn-mini demo-reload">重试</a>');
demoText.find('.demo-reload').on('click', function () {
uploadInst.upload();
});
}
});

  Controller代码

//前端选择图片 传入后端,修改名字保存进数据库
@RequestMapping(value = "/uploadFile", method = RequestMethod.POST)
@ResponseBody
public Map uploadPicture(@RequestParam("file") MultipartFile file) {
Map<String, Object> res = new HashMap<>();
File targetFile = null;
//返回存储路径
String url = "";
//获取文件名加后缀
String fileName = file.getOriginalFilename();
if (fileName != null && fileName != "") {
//文件临时存储位置到target路径上,保证上传不用重启就能看到
String path = ClassUtils.getDefaultClassLoader().getResource("static").getPath() + File.separator + "images"; //文件后缀
String fileSuffix = fileName.substring(fileName.lastIndexOf("."));
//最后的文件名
fileName = System.currentTimeMillis() + "_" + new Random().nextInt(1000) + fileSuffix; //获取文件夹路径
path = path + File.separator;
File file1 = new File(path);
//如果文件夹不存在则创建
if (!file1.exists() && !file1.isDirectory()) {
file1.mkdirs();
}
//将图片存入文件夹
targetFile = new File(file1, fileName);
try {
//将上传的文件写到服务器上指定的文件。
file.transferTo(targetFile);
//本项目所在位置D:\CRM-Test\code\honda-project-all
String projectPath = System.getProperty("user.dir");
//文件复制
String src = path + fileName;
//web项目实际路径D:\CRM-Test\code\honda-project-all\honda-web\src\main\resources\static\images
String destDir = projectPath + File.separator + "honda-web" + File.separator + "src" + File.separator + "main" + File.separator + "resources" + File.separator + "static" + File.separator + "images" + File.separator;
//文件上传读取
copyFile(src, destDir, fileName);
//数据库只存名字
url = fileName;
res.put("data", url);
res.put("code", "0");
res.put("msg", "");
return res;
} catch (Exception e) {
e.printStackTrace();
}
}
return res;
}

  文件上传读取

/**
* 文件复制
*
* @param src
* @param destDir
* @param fileName
* @throws IOException
*/
public void copyFile(String src, String destDir, String fileName) throws IOException {
FileInputStream in = new FileInputStream(src);
File fileDir = new File(destDir);
if (!fileDir.isDirectory()) {
fileDir.mkdirs();
}
File file = new File(fileDir, fileName); if (!file.exists()) {
file.createNewFile();
}
FileOutputStream out = new FileOutputStream(file);
int c;
byte buffer[] = new byte[1024];
while ((c = in.read(buffer)) != -1) {
for (int i = 0; i < c; i++) {
out.write(buffer[i]);
} }
in.close();
out.close();
}

  前端点击查看服务器上的图片

<script type="text/html" id="herfFormalUrl">
<a href="{{'http://localhost:8080/static/images/'+d.pictureUrl}}" class="layui-table-link">查看</a>
</script>

  动态表格超链接查看图片

    //图片库表格
var goodtable = table.render({
elem: '#demo'
, url: '/getPicture' //数据接口
, page: true //开启分页
, limit: 10
, limits: [10]
, cols: [
[ //表头
{checkbox: true, fixed: 'left'}
, {field: 'tmPictureId', title: '编号', width: 100, sort: true, fixed: 'left'}
, {field: 'pictureNo', title: '图片编号', width: 120}
, {field: 'pictureName', title: '图片名称', width: 120, sort: true}
, {field: 'proPictureName', title: '图片类型', width: 120}
, {field: 'carseriesNo', title: '车系', width: 120}
, {field: 'featureNo', title: '机种', width: 120, sort: true}
, {field: 'pictureUrl', title: '图片浏览', width: 120, sort: true, templet: '#herfFormalUrl'}//表格中点击查看图片的超链接
, {field: 'createTime', title: '创建时间', width: 180, sort: true}
, {field: 'remark', title: '备注', width: 228, sort: true}
]
]
});

layui框架图片上传至服务器的更多相关文章

  1. .net mvc + layui做图片上传(一)

    图片上传和展示是互联网应用中比较常见的一个功能,最近做的一个门户网站项目就有多个需要上传图片的功能模块.关于这部分内容,本来功能不复杂,但后面做起来却还是出现了一些波折.因为缺乏经验,对几种图片上传的 ...

  2. .net mvc + layui做图片上传(二)—— 使用流上传和下载图片

    摘要:上篇文章写到一种上传图片的方法,其中提到那种方法的局限性,就是上传的文件只能保存在本项目目录下,在其他目录中访问不到该文件.这与浏览器的安全性机制有关,浏览器不允许用户用任意的路径访问服务器上的 ...

  3. MVC图片上传、浏览、删除 ASP.NET MVC之文件上传【一】(八) ASP.NET MVC 图片上传到服务器

    MVC图片上传.浏览.删除   1.存储配置信息 在web.config中,添加配置信息节点 <appSettings> <add key="UploadPath" ...

  4. php form 图片上传至服务器上

    本文章也是写给自己看的,因为写的很简洁,连判断都没有,只是直接实现了能上传的功能. 前台: <form action="upload.php" method="PO ...

  5. 使用canvas给图片添加水印, canvas转换base64,,canvas,图片,base64等转换成二进制文档流的方法,并将合成的图片上传到服务器,

    一,前端合成带水印的图片 一般来说,生成带水印的图片由后端生成,但不乏有时候需要前端来处理.当然,前端处理图片一般不建议,一方面js的处理图片的方法不全,二是有些老版本的浏览器对canvas的支持度不 ...

  6. thinkphp5+layui多图片上传

    准备资料 下载layui <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...

  7. 根目录97 <input file>标签,把图片上传到服务器(跟增删改查一起实现)

    首先来个简单的html页面: enctype="multipart/form-data" encoding="multipart/form-data" acti ...

  8. laravel框架图片上传

    1.建控制器方法 2.建立路由 绑定控制器方法 3.进行图片上传的配置 修改图片上传的路径 a) config/filesystems.php 修改disks->local->root(图 ...

  9. .Net之Layui多图片上传

    前言: 多图上传在一些特殊的需求中我们经常会遇到,其实多图上传的原理大家都有各自的见解.对于Layui多图上传和我之前所说的通过js获取文本框中的文件数组遍历提交的原理一样,只不过是Layui中的up ...

随机推荐

  1. python模块详情与开发规范

    目录 循环导入 py文件类型 模块的查找顺序 相对导入与绝对导入 包 软件开发目录规范 循环导入 在初学模块时,我们有些时候会出现两个文件彼此导入,这时候可能会有报错. 比如有以下两个py文件 a.p ...

  2. 线性求 $i^i$ 的做法

    线性求 \(i^i\) 的做法 方便起见,我们记 \(f_i=i^i\),\(i\) 的最小质因子为 \(p=\mathrm{minp}(i)\),第 \(i\) 个质数为 \(\mathrm{pr} ...

  3. 【SignalR全套系列】之在.Net Core 中实现SignalR实时通信

    ​ 微信公众号:趣编程ACE 关注可了解更多的.NET日常实战开发技巧,如需源码 请公众号后台留言 源码 [如果觉得本公众号对您有帮助,欢迎关注] 前文回顾 [SignalR全套系列]之在.NetCo ...

  4. (持续更新)虚树,KD-Tree,长链剖分,后缀数组,后缀自动机

    真的就是讲课两天,吸收一个月呢! \(1.\)虚树 \(2.\)KD-Tree \(3.\)长链剖分 \(4.\)后缀数组 后缀数组 \(5.\)后缀自动机 后缀自动机

  5. 【Java面试】TCP协议为什么要设计三次握手?

    一个工作5年的粉丝,最近去面试了很多公司,每次都被各种技术原理题问得语无伦次. 由于找了快1个月时间的工作,有点焦虑,来向我求助. 我能做的只是保证每天更新一个面试题,然后问他印象最深刻的一个面试题是 ...

  6. 修改windows字符集

    手动 临时修改cmd默认字符集(代码页) chcp xxxx 自动<打开cmd后应该自动运行dhcp 65001,临时设置为utf-8> D:\Develope\apache-tomcat ...

  7. 摸鱼人常备5个Python迷你项目,玩一整天不是问题(附源码)

    大家好鸭,我是小熊猫 在使用Python的过程中,我最喜欢的就是Python的各种第三方库,能够完成很多操作. 下面就给大家介绍5个通过Python构建的项目,以此来学习Python编程. 一.石头剪 ...

  8. List集合五种遍历方式

    一.使用Iterator接口遍历 二.普通for循环遍历 三.增强for循环遍历 四.List集合自带迭代器 五.Lambda(JDK8新增特性) //使用多态方式创建对象 List<Strin ...

  9. [零基础学IoT Pwn] 复现Netgear WNAP320 RCE

    [零基础学IoT Pwn] 复现Netgear WNAP320 RCE 0x00 前言: 这是[零基础学IoT Pwn]的第二篇,上篇我们搭好了仿真环境后,模拟运行了Netgear WNAP320固件 ...

  10. FastASR——PaddleSpeech的C++实现

    FastASR 基于PaddleSpeech所使用的conformer模型,使用C++的高效实现模型推理,在树莓派4B等ARM平台运行也可流畅运行. 项目简介 本项目仅实现了PaddleSpeech ...