struts上传图片

文件上传的三种方案

1.上传到tomcat服务器

自己的电脑:项目在哪里,图片在哪里

云服务器:没有CDEF盘,只有/根目录

2.上传到指定文件目录,添加服务器与真实目录的映射关系

文件服务器与web服务器通常是同一个,但是文件目录与tomcat目录肯定不是同一个

3.在数据库表中建立二进制字段,将图片存储到数据库(安全性比第二种高)

公司一般不备份文件资源,但会频繁备份数据库的数据

struts上传的注意点:

1,多功能表单:enctype="multipart/form-data"   type="file"

2,struts必须按照指定的格式去接收参数变量

1.上传文件界面   

开发:reUpload.jsp

<form action="${pageContext.request.contextPath }/sy/clz_upload.action" method="post" enctype="multipart/form-data">
<input type="hidden" name="cid" value="${result.cid }"><br>
<input type="hidden" name="cname" value="${result.cname }"><br>
<input type="hidden" name="cteacher" value="${result.cteacher }"><br>
<input type="file" name="img"><br>
<input type="submit">
</form>

2.struts必须按照指定格式去接受参数变量

①上传的文件        file

②上传的文件名        fileFileName

③上传的文件类别        fileContextType

上传方法:

将指定的文件图片上传到文件目录

将访问图片的请求映射地址更新到数据

        // 将指定文件上传到文件目录
    public String preUpload() throws Exception {
        this.result = this.clzDao.list(clz, null).get(0);
        this.req.setAttribute("result", result);
        return "upload";
    }

     public String upload() throws Exception {

//        img代表选择的文件或者图片,接下来要将图片上传到其他地方
//        img代表源头,要将其写入目的地target
        String destDir = "D:/easyui/EasyUi_xm/WebContent/uploadImages";//改成顺斜杠,支持windows和unix
        String serverDir = "/uploadImages";
        FileUtils.copyFile(img, new File(destDir + "/" + imgFileName));
        clz.setPic(serverDir + "/" + imgFileName);
        this.clzDao.edit(clz);
        return TOLIST;
    }

首先调用list方法查询到单条数据

然后调用修改的方法对图片路径进行修改

配置

<result name="reUpload">/reUpload.jsp</result>

3.配置tomcat映射位置(service.xml)

<Context path="/uploadImages" docBase="E:/temp/"/> 

 效果如下

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小宝的宝呢

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值