SprimgMVC学习笔记(七)—— 上传图片

一、配置虚拟目录

  在tomcat上配置图片虚拟目录,在tomcat下conf/server.xml中添加:

<Context docBase="D:\upload\temp" path="/pic" reloadable="false"/>

  访问http://localhost:8080/pic即可访问D:\upload\temp下的图片。

  也可以通过eclipse配置,如下图:

  

  

  复制一张图片到存放图片的文件夹,使用浏览器访问

  测试效果,如下图:

  

 

  idea设置tomcat虚拟路径的两种方法

二、加入jar包

  

三、配置上传解析器

  在springmvc.xml中配置文件上传解析器

  <!-- 文件上传,id必须设置为multipartResolver  -->
    <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
        <!-- 设置文件上传大小 -->
        <property name="maxUploadSize" value="5000000"></property>
    </bean>

四、修改jsp页面

  修改itemEdit.jsp:

  

  

五、实现图片上传

  在更新商品方法中添加图片上传逻辑

复制代码
/**
 * 更新商品
 * 
 * @param item
 * @return
 * @throws Exception
 */
@RequestMapping("updateItem")
public String updateItemById(Item item, MultipartFile pictureFile) throws Exception {
    // 图片上传
    // 设置图片名称,不能重复,可以使用uuid
    String picName = UUID.randomUUID().toString();

    // 获取文件名
    String oriName = pictureFile.getOriginalFilename();
    // 获取图片后缀
    String extName = oriName.substring(oriName.lastIndexOf("."));

    // 开始上传
    pictureFile.transferTo(new File("C:/upload/image/" + picName + extName));

    // 设置图片名到商品中
    item.setPic(picName + extName);
    // ---------------------------------------------
    // 更新商品
    this.itemService.updateItemById(item);

    return "forward:/itemEdit.action";
}
复制代码

  效果如下:

  

 

posted @   yi0123  阅读(354)  评论(0编辑  收藏  举报
编辑推荐:
· 从二进制到误差:逐行拆解C语言浮点运算中的4008175468544之谜
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
阅读排行:
· 《HelloGitHub》第 108 期
· Windows桌面应用自动更新解决方案SharpUpdater5发布
· 我的家庭实验室服务器集群硬件清单
· C# 13 中的新增功能实操
· Supergateway:MCP服务器的远程调试与集成工具
点击右上角即可分享
微信分享提示