layui上传图片详解(附代码)
前端  /  管理员 发布于 5年前   460
            
layui上传与bootstrap上传相似,只是不需要下插件,
layui自带的已够用 先看一下前台界面,这里是用到的上传头像

先点击开始上传,头像上传至服务器中,
返回json添加至form表单中,与其他数据一起提交
先看一下jsp界面
<%@ page language="java" contentType="text/html; charset=UTF-8"    pageEncoding="UTF-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>个人资料</title><link href="${pageContext.request.contextPath }/js/layui/css/layui.css"    rel="stylesheet" /><script src="${pageContext.request.contextPath }/js/layui/layui.js"    charset="utf-8"></script><script src="${pageContext.request.contextPath }/js/jquery-1.8.3.js"></script><script type="text/javascript">        layui.use('upload',function(){            var upload = layui.upload;            upload.render({                elem: '#fileBtn'                ,url: '../updatePersonalById.do'                ,accept: 'file'                ,auto: false                ,bindAction: '#uploadBtn'                ,done: function(res){                    alert(res.data.src);                    $("[name=userImage]").val(res.data.src);                }            });        });    </script></head><body>    <form class="layui-form" action="../updatePersonalByIdSuccess.do" method="post" charset="utf-8" target="_parent">         <div class="layui-form-item" style="margin-top: 20px;">            <label class="layui-form-label">编号</label>            <div class="layui-input-block">              <input type="text" name="userId" required  lay-verify="required" value="${ui.userId }" autocomplete="off" readonly="readonly" class="layui-input">            </div>          </div>           <div class="layui-form-item" style="margin-top: 20px;">            <label class="layui-form-label">登录名</label>            <div class="layui-input-block">              <input type="text" name="userName" required  lay-verify="required" value="${ui.userName }" autocomplete="off" readonly="readonly" class="layui-input">            </div>          </div>           <div class="layui-form-item" style="margin-top: 20px;">            <label class="layui-form-label">密码</label>            <div class="layui-input-block">              <input type="password" name="userPwd" required  lay-verify="required" value="${ui.userPwd }" autocomplete="off" class="layui-input">            </div>          </div>          <div class="layui-form-item" style="margin-top: 20px;">            <label class="layui-form-label">确认密码</label>            <div class="layui-input-block">              <input type="password" name="reuserPwd" required  lay-verify="required" value="${ui.userPwd }" autocomplete="off" class="layui-input">            </div>          </div>           <div class="layui-form-item" style="margin-top: 20px;">            <label class="layui-form-label">真实姓名</label>            <div class="layui-input-block">              <input type="text" name="userrealName" required  lay-verify="required" value="${ui.userrealName }" autocomplete="off" class="layui-input">            </div>          </div>           <div class="layui-form-item" style="margin-top: 20px;">            <label class="layui-form-label">电话</label>            <div class="layui-input-block">              <input type="text" name="userPhone" required  lay-verify="required" value="${ui.userPhone }" autocomplete="off" class="layui-input">            </div>          </div>           <div class="layui-form-item" style="margin-top: 20px;">            <label class="layui-form-label">地址</label>            <div class="layui-input-block">              <input type="text" name="userAds" required  lay-verify="required" value="${ui.userAds }" autocomplete="off" class="layui-input">            </div>          </div>          <div class="layui-upload">                <label class="layui-form-label">头像:</label>                <div class="layui-upload layui-input-block">                    <input type="hidden" name="userImage" value="${ui.userImage }" required lay-verify="required" />                    <button type="button" class="layui-btn layui-btn-primary" id="fileBtn"><i class="layui-icon"></i>选择文件</button>                    <button type="button" class="layui-btn layui-btn-warm" id="uploadBtn">开始上传</button>                </div>            </div>             <div class="layui-form-item" style="margin-top: 20px;">                  <div class="layui-input-block">                  <button class="layui-btn" id="btn1" lay-submit lay-filter="formDemo">提交</button>                  <button type="reset" class="layui-btn layui-btn-primary">重置</button>                </div>             </div>              </form></body></html>与Controller交互的.do
package com.supermanager.controller;import java.io.File;import java.io.IOException;import java.util.Date;import java.util.List;import java.util.Random;import javax.annotation.Resource;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpSession;import org.springframework.context.annotation.Scope;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.ModelAttribute;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RequestParam;import org.springframework.web.bind.annotation.ResponseBody;import org.springframework.web.multipart.MultipartFile;import com.supermanager.entity.LogsInfo;import com.supermanager.entity.RoleInfo;import com.supermanager.entity.StoragesInfo;import com.supermanager.entity.UserInfo;import com.supermanager.service.LogsService;import com.supermanager.service.RoleInfoService;import com.supermanager.service.StoragesService;import com.supermanager.service.UserInfoService;import net.sf.json.JSONArray;@Controller@Scope("prototype")public class UserInfoController {    @Resource    private UserInfoService userInfoService;    @Resource    private LogsService logService;    @Resource    private RoleInfoService roleInfoService;    @Resource    private StoragesService storagesService;        /**     * 修改个人资料     * @param session     * @param file     * @param ui     * @return     * @throws IOException      * @throws IllegalStateException      */    @RequestMapping(value="updatePersonalById")    public @ResponseBody String updatePersonal(@RequestParam("file") MultipartFile file,@ModelAttribute UserInfo ui,HttpServletRequest request) throws IllegalStateException, IOException{        String oldName = file.getOriginalFilename();        String path = request.getServletContext().getRealPath("/upload/");        String fileName = changeName(oldName);        String rappendix = "upload/" + fileName;        fileName = path + "/" + fileName;        File file1 = new File(fileName);        file.transferTo(file1);        String str = "{\"code\": 0,\"msg\": \"\",\"data\": {\"src\":\"" + rappendix + "\"}}";        return str;    }    public static String changeName(String oldName){        Random r = new Random();        Date d = new Date();        String newName = oldName.substring(oldName.indexOf('.'));        newName = r.nextInt(99999999) + d.getTime() + newName;        return newName;    }    @RequestMapping(value="updatePersonalByIdSuccess")    public  String updatePersonalByIdSuccess(@ModelAttribute UserInfo ui){        UserInfo uif = userInfoService.FindUserByUserId(ui.getUserId());        ui.setRoleId(uif.getRoleId());        ui.setUserSex(uif.getUserSex());        ui.setUserAge(uif.getUserAge());        int a = userInfoService.Update(ui);        if(a!=0){            return "redirect:exitSystem.do";        }        return "error";    }            }上传成功之后的效果如图

更多layui相关文章请关注layui使用教程栏目。
以上就是layui上传图片详解(附代码)的详细内容,更多请关注其它相关文章!
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
			Copyright·© 2019 侯体宗版权所有·
			粤ICP备20027696号
			 
			
