`

struts2上传-待完善

阅读更多
< action name ="fileUpload" class ="tutorial.FileUploadAction" >
            < interceptor-ref name ="fileUpload" >
<!-- 单位为字节,这里为400k 这里的大小是指每个文件上传的大小,若多个文件上传指每一个文件的大小 -->
    <param name="maximumSize">409600</param>
                < param name ="allowedTypes" >
                    image/bmp,image/png,image/gif,image/jpeg
                </ param >
            </ interceptor-ref >
            < interceptor-ref name ="defaultStack" />           
            < result name ="input" > /FileUpload.jsp </ result >
            < result name ="success" > /ShowUpload.jsp </ result >
        </ action >

< s:form action ="fileUpload" method ="POST" enctype ="multipart/form-data" >
        < s:file name ="myFile" label ="Image File" />
        < s:textfield name ="caption" label ="Caption" />       
        < s:submit />
    </ s:form >


<s:file/>标志不仅仅是绑定到myFile,还有myFileContentType(上传文件的MIME类型)和myFileFileName(上传文件的文件名,该文件名不包括文件的路径)。因此,<s:file name="xxx" />对应Action类里面的xxx、xxxContentType和xxxFileName三个属性




jsp页面:
<%@ page language="java" contentType="text/html; charset=GBK"
    pageEncoding="GBK"%>
<%@ taglib prefix="s" uri="/struts-tags" %>
<!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=GBK">
<title>Insert title here</title>
</head>
<script type="text/javascript">
  // 显示图片的js
function viewimg(){
var imgup=document.getElementById("uploadimg");
var imgpath=getPath(imgup);
//判断是否是图片格式
var imgname=imgup.value.substring(imgup.value.lastIndexOf("."),imgup.value.length)
imgname=imgname.toLowerCase()
if ((imgname!='.jpg')&&(imgname!='.gif')&&(imgname!='.jpeg')&&(imgname!='.png')&&(imgname!='.bmp')){
alert("请选择图片文件,谢谢!");
imgup.focus();
//清空file里面的值
imgup.select();  
document.selection.clear();

}
else{
//显示图片
document.getElementById("sig_preview").innerHTML="<img src='"+imgpath+"' border=0 width=100 height=60>"
}
}
//该函数解决iE下路径问题。兼容ie6,7,firefox add by exceljava 2010-1-6
function getPath(obj){
   if(obj){
   if (window.navigator.userAgent.indexOf("MSIE")>=1){
     obj.select();
     return document.selection.createRange().text;
   }else if(window.navigator.userAgent.indexOf("Firefox")>=1){
     if(obj.files){
         return obj.files.item(0).getAsDataURL();  
     }
     return obj.value;
   }   
   return obj.value;   
   }
}



</script>
<body>
<s:form action ="fileUpload" namespace="/fileUploadDemo" method ="POST" enctype ="multipart/form-data">
<s:file id="uploadimg"  size="40" name="upload" onchange="viewimg()"></s:file>     
    <s:submit />
</s:form>

<!-- 显示的div -->
<div id="sig_preview"></div>
</body>
</html>

action代码:
package UploadImages;

import java.io.File;

import javax.servlet.ServletContext;

import org.apache.commons.io.FileUtils;
import org.apache.struts2.util.ServletContextAware;

import com.opensymphony.xwork2.ActionSupport;

public class FileUploadAction extends ActionSupport implements
        ServletContextAware {

    private File upload;// 实际上传文件

    private String uploadContentType; // 文件的内容类型

    private String uploadFileName; // 上传文件名

    private String fileCaption;// 上传文件时的备注
   
    private ServletContext context;

    public String execute() throws Exception {

        try {
           
            String targetDirectory = context.getRealPath("/UploadImages");
            String targetFileName = uploadFileName;
            File target = new File(targetDirectory, targetFileName);
            FileUtils.copyFile(upload, target);  
       } catch (Exception e) {

            addActionError(e.getMessage());

            return INPUT;
        }

        return SUCCESS;

    }

    public String getFileCaption() {
        return fileCaption;
    }

    public void setFileCaption(String fileCaption) {
        this.fileCaption = fileCaption;
    }

    public File getUpload() {
        return upload;
    }

    public void setUpload(File upload) {
        this.upload = upload;
    }

    public String getUploadContentType() {
        return uploadContentType;
    }

    public void setUploadContentType(String uploadContentType) {
        this.uploadContentType = uploadContentType;
    }

    public String getUploadFileName() {
        return uploadFileName;
    }

    public void setUploadFileName(String uploadFileName) {
        this.uploadFileName = uploadFileName;
    }

    public void setServletContext(ServletContext context) {
        this.context = context;
    }


}
上传后显示页面:
<%@page contentType = "text/html;charset=GBK" pageEncoding = "GBK" %>
<%@taglib prefix="s" uri="/struts-tags" %>

<! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd" >
<html xmlns ="http://www.w3.org/1999/xhtml">
<head>
    <title> Struts 2 File Upload </title>
</head>
<body>
    <div style ="padding: 3px; border: solid 1px #cccccc; text-align: center">
        <img src ='/UploadImages/<s:property value ="uploadFileName" /> '/>
        <br/>
        <s:property value ="caption"/>
    </div>
</body>
</html>
struts配置文件:
<package name ="fileUploadDemo" extends ="struts-default" namespace="/fileUploadDemo">
        <action name ="fileUpload" class ="UploadImages.FileUploadAction">
            <interceptor-ref name ="fileUpload">
            <param name ="allowedTypes" >
                    image/bmp,image/png,image/gif,image/jpeg
                </param >   
            </interceptor-ref>
            <interceptor-ref name ="defaultStack" />     
            <result name ="success">/fileUploadDemo/showUpload.jsp</result>
        </action>
    </package>








String.prototype.isTel = function()//电话校验
{
    return (/^([\d\*#\+PpWw]){0,30}$/.test(this.trim()));
}

String.prototype.isZipCode = function()//邮编校验
{
    return (/^([\d]){0,10}$/.test(this.trim()));
}

String.prototype.trim = function()//去除空格

var m = this.match(/^\s*(\S+(\s+\S+)*)\s*$/); 
return (m == null) ? "" : m[1]; 
}

len = function(v)
{
        var r = 0;
        var t = v.split("");
        for (var i=0;i<t.length;i++) {
            if (t[i].charCodeAt(0)<299) {
                r++;
            } else {
                r+=2;
            }
        }
        return r;
    }
patterns.email = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/;
var pattern = /^[0-9]{11}$/;
分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    struts2上传下载

    1. **依赖引入**:使用Struts2进行文件上传,需要引入`struts2-convention-plugin`和`struts2-file-uploading-plugin`插件。确保`struts.xml`配置文件中包含必要的拦截器栈。 2. **表单设计**:创建一个HTML表单,...

    Struts2文件上传下载

    总结来说,Struts2提供了完善的文件上传和下载机制,通过配置Action、处理文件对象以及设置HTTP响应头,可以轻松实现这些功能。不过,随着技术的发展,理解和掌握最新版本的Struts2或其他现代框架的文件操作方法同样...

    struts实现的上传下载

    Struts是Apache软件基金会下的一个开源框架,主要应用于Java Web应用程序的开发。它基于Model-View-Controller(MVC)设计模式,旨在简化...如果希望进一步完善,建议查看Struts官方文档、社区讨论或进行更深入的学习。

    struts04:多文件上传、文件上传与国际化

    要实现多文件上传,我们需要在Struts的ActionForm中定义一个字段数组,类型为`File`,每个元素对应一个待上传的文件。同时,还需要对应的`String`类型的字段来存储文件名。在JSP页面上,使用`&lt;s:file&gt;`标签为每个...

    SSH2框架权限管理、上传文件、导出报表和注册审核

    在SSH2中,可以使用Struts2的FileUpload interceptor或者Spring的MultipartFile接口来处理文件上传。开发者需要考虑文件大小限制、文件类型验证、文件存储位置以及错误处理等问题,以确保文件上传过程的安全和稳定。...

    SSH实现的OA系统

    3. 文档管理:上传、下载、共享文档,Struts2用于处理文件上传,而Spring和Hibernate处理文件存储和检索。 4. 流程审批:实现工作流的定义、执行和监控,可能需要用到第三方工作流引擎,如Activiti,并结合Spring...

    bextjs 多文件上传

    `struts2`提供了一套完善的文件上传拦截器,可以方便地处理文件接收、存储以及验证大小和类型等安全问题。在`jsp`页面上,我们通常会创建一个Action类来处理上传的文件,并将其保存到服务器的指定目录。 6. **错误...

    基于SSH框架的网上商城设计与开发

    Struts2还支持多种插件,如文件上传下载、拦截器、验证框架等,这些都极大地提高了开发效率。 ##### 2. Spring框架 Spring是一个轻量级的Java开发框架,它提供了全面的解决方案来解决企业应用开发中的各种问题。...

    基于SSH 的网上购物系统

    2. **商品展示**:商品分类、搜索、详情展示,支持商品的多图上传和预览。 3. **购物车**:用户可以将商品添加到购物车,调整数量,查看购物车总金额,以及选择结算。 4. **订单处理**:生成订单、支付接口集成、...

    ssh博客系统

    在SSH框架下,可以通过Struts2的拦截器或者自定义标签来实现分页显示。 异步处理是指在用户提交请求后,服务器不会立即返回结果,而是先处理其他请求,待处理完成后再将结果反馈给用户。这种方式提高了系统的响应...

    基于Javaweb的员工报销系统.zip

    - **申请报销**:员工通过系统提交报销单,填写详细信息并上传相关凭证,系统自动保存并提交至待审状态。 - **报销审核**:管理员登录系统,查看待审报销单,根据实际情况批准或拒绝报销请求,同时系统会记录审批...

    基于JavaEE的个人数字图书馆的设计与实现图书管理系统学位学士论文.doc

    ### 基于JavaEE的个人数字图书馆的设计与实现 #### 概述 随着信息技术的飞速发展,信息量呈爆炸式增长,这对个人的信息...未来,随着技术的进步和个人需求的变化,个人数字图书馆的功能和服务也将不断完善和优化。

    在线图书销售管理系统的设计与实现.docx

    另一方面,物流配送体系的完善也为在线图书销售提供了有力支持。在此背景下,“有朋在线图书销售管理系统”的设计与实现显得尤为重要。该系统不仅能够帮助实体书店拓展线上销售渠道,还能提高运营效率和服务质量,...

    手机销售详细设计

    手机商城销售系统是一个...综上,该手机销售系统详细设计项目利用SSHJPA框架,构建了一个功能完善的线上手机销售平台,既满足了消费者的购物需求,也为商家提供了便捷的后台管理工具,实现了业务流程的自动化和信息化。

    j2ee_project:二手房交易平台

    【描述】在"j2ee_project"的开发过程中,开发者列出了以下几个关键待办事项: 1. **新闻源的选择**:平台可能需要集成一个可靠的新闻API,以提供实时的房地产市场动态和政策信息,帮助用户做出更明智的购房决策。这...

Global site tag (gtag.js) - Google Analytics