`

EWeb4J-1.9-文件上传下载和生成建表脚本

阅读更多
毕业了。高兴一下,哈。

一直以来,eweb4j framework新版本都没有发布,因为忙工作、忙毕业、忙答辩。

只好在有空的时候为框架添加新特性、重构旧代码来弥补了。

写本文之前,修复了一些小bug,增加了两个特性:文件上传下载、生成建表脚本。

1.文件上传下载:

文件上传下载?这要涉及到文件IO流吧。或者,用第三方组件?例如Apache 的common-upload, 不不不,咱都不用,咱直接在控制器里声明一个 File 对象就行了。什么?这么简单?先看看代码吧~
public class UploadControl{
    private File file;
    
    public String doAtPost(){
        FileUtil.copy(file, new File("c://"+file.getName()));
    }

    public void setFile(File file){
        this.file = file;
    }
}

upload.html
<form action="upload" method="POST" enctype="multipart/form-data">
    <input type="file" name="file" />
    <input type="submit" value="上传" />
</form>

PS:注意表单文件input的name要和控制器声明的File对象名一致(实质上是和setter方法名相关)。另外注意 enctype

就这么简单,在一个Action方法执行前,框架会自动接收所有的文件上传请求,并将其作为一个临时文件保存到临时目录里,然后Action方法执行之后,框架会自动清空这些临时文件。因此,我们只要在Action方法体中,将临时文件拷贝到另外一个目录即可。下面有一个更加全面的例子:
//文件上传
public class UploadControl {
        
    final static String path = ConfigConstant.ROOT_PATH + "/WEB-INF/uploads/";

    private File tmpFile1;
    private UploadFile tmpFile2;
        
    private File[] tmpFile3;
    private UploadFile[] tmpFile4;

    public String doAtGet() {
            
        return "fmt:Upload/upload.html";
    }
        
    public String doAtPost() {
        //为了查看临时文件,当前线程睡眠10秒钟
        //Thread.sleep(10*1000);
                
        FileUtil.copy(tmpFile1, new File(path + tmpFile1.getName()));
                
        FileUtil.copy(tmpFile2.getTmpFile(), new File(path + tmpFile2.getFileName()));
                
        for (File f : tmpFile3)
            FileUtil.copy(f, new File(path + f.getName()));
        
        for (UploadFile f : tmpFile4)
            FileUtil.copy(f.getTmpFile(), new File(path + f.getFileName()));
                
        return StringUtil.getNowTime()+"上传成功!" ;
    }

    //别忘记setter方法哦
}


upload.html
<h1>EWeb4J Framework File Upload Demo</h1>
<form action="${BaseURL}upload" method="post" enctype="multipart/form-data">
    <label>tmpFile1:</label><input type="file" name="tmpFile1" />
    <label>tmpFile2:</label><input type="file" name="tmpFile2" />

    <label>tmpFile3:</label><input type="file" name="tmpFile3" />
    <label>tmpFile3:</label><input type="file" name="tmpFile3" />

    <label>tmpFile4:</label><input type="file" name="tmpFile4" />
    <label>tmpFile4:</label><input type="file" name="tmpFile4" />
        
    <input type="submit" value="上传" />
</form>

文件上传这么简单,我想聪明的你应该猜到,文件下载大概怎么做了吧!没错,仅需要在Action方法里返回一个File对象即可!如果有多个文件,那么请返回文件数组吧!框架会自动将其打包成zip。
public class DownloadControl {

    final static String path = ConfigConstant.ROOT_PATH + "/WEB-INF/uploads/";
    final File file = new File(path+"just4download.jpg"); 
        
    public File doAtGet(){
        return file;
    }
        
    public File[] doArrayAtGet(){
        return new File[]{file};
    }
        
}

PS:框架采用标准的HTTP文件下载的方式进行响应,客户端可以自己修改文件下载保存名字。
response.setContentType("application/zip");  
response.addHeader("Content-Disposition", "attachment; filename=xxx");


2.生成建表脚本:

首先,编写模型类

/**
 * 宠物 模型
 * @author weiwei
 *
 */
@Entity
@Table(name="t_pet")
public class Pet extends Model{
    public final static Pet inst = new Pet();
	
    /* 宠物名字 */
    @Column(unique=true)
    private String name;
    /* 宠物性别 1公 0母*/
    private boolean gender;
    /* 物种 */
    private String species;
    /* 宠物价格 */
    private float price;
    /* 宠物年龄  单位 月*/
    private int age;
    /* 是否已上架 */
    @Column(name="is_up")
    private boolean isUp;
    /* 所属主人 */
    @Column(nullable=false)
    @ManyToOne
    private Member master;
    /* 所属分类 */
    @ManyToOne
    private Category category;
	
    @Transient
    public long count;

    //setter and getter
}

/**
 * 购物车 模型
 * 
 * @author weiwei
 * 
 */
@Entity
@Table(name = "t_cart")
public class Cart extends Model {

    @ManyToMany
    @JoinTable(name = "t_cart_pet", joinColumns = @JoinColumn(name = "cart_id"), inverseJoinColumns = @JoinColumn(name = "pet_id"))
    private List<Pet> pets = new ArrayList<Pet>();

    @Column(nullable=false)
    private String description;

    //setter and getter
}

然后执行这样一句代码:
public static void main(String[] args){
    String CONF_DIR = FileUtil.getTopClassPath(EWeb4JConfig.class)+"/conf/";
    EWeb4JConfig.setCONFIG_BASE_PATH(CONF_DIR);
    EWeb4JConfig.start("start.xml");
    /* 框架根据模型类生成数据库pet_store_db建表脚本文件 */
    Model2Table.write("pet_store_db");
}

执行之后会生成 ${ClassPath}/conf/mysql-create.sql文件,内容如下:
DROP DATABASE IF EXISTS pet_store_db;
CREATE DATABASE pet_store_db DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
SET FOREIGN_KEY_CHECKS=0;
USE pet_store_db;

-- ----------------------------
-- Created by EWeb4J Framework 1.9-SNAPSHOT
-- at 2012-06-09 11:59:53
-- Models of models.Pet
-- Records of t_pet
-- ----------------------------
DROP TABLE IF EXISTS t_pet;
CREATE TABLE t_pet(
    id bigint (20)  NOT NULL  AUTO_INCREMENT , 
    name varchar (255)  NOT NULL , 
    gender boolean NOT NULL , 
    species varchar (255)  NOT NULL , 
    price float (8)  NOT NULL , 
    age tinyint (4)  NOT NULL , 
    is_up boolean NOT NULL , 
    master_id bigint (20) , 
    category_id bigint (20)  NOT NULL , 
    UNIQUE KEY name (name), 
    PRIMARY KEY (id), 
    KEY master_id (master_id), 
    CONSTRAINT master_id FOREIGN KEY (master_id) REFERENCES t_member (id), 
    KEY category_id (category_id), 
    CONSTRAINT category_id FOREIGN KEY (category_id) REFERENCES t_category (id) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------
-- Created by EWeb4J Framework 1.9-SNAPSHOT
-- at 2012-06-09 11:59:54
-- Models of models.Cart
-- Records of t_cart
-- ----------------------------
DROP TABLE IF EXISTS t_cart;
CREATE TABLE t_cart(
    id bigint (20)  NOT NULL  AUTO_INCREMENT , 
    description varchar (255) , 
    PRIMARY KEY (id) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------
-- Created by EWeb4J Framework 1.9-SNAPSHOT
-- at 2012-06-09 11:59:54
-- Records of t_cart_pet
-- ----------------------------
DROP TABLE IF EXISTS t_cart_pet;
CREATE TABLE t_cart_pet(
    id bigint (20) NOT NULL AUTO_INCREMENT,
    cart_id bigint (20) ,
    pet_id bigint (20) ,
    PRIMARY KEY (id), 
    KEY cart_id (cart_id), 
    CONSTRAINT t_cart_pet_cart_id FOREIGN KEY (cart_id) REFERENCES t_cart (id), 
    KEY pet_id (pet_id), 
    CONSTRAINT t_cart_pet_pet_id FOREIGN KEY (pet_id) REFERENCES t_pet (id) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8;


可以看到,多对多关系中的第三方表也会自动生成。

谢谢。

PS:如果希望获取EWeb4J最新版本,直接使用Maven添加依赖,版本号为:1.9-SNAPSHOT即可。另外还可以通过项目主页源码svn签出也行。
2
1
分享到:
评论

相关推荐

    java猜数字源码-eweb4j-framework:简单的Java网络框架

    超级方便的文件上传下载 超级方便的视图数据传递 充血模型 声明式事务、事务模板、事务嵌套 丰富的DAO封装类 多数据源、表关联 简单的 IOC 容器 MVC、ORM、IOC 可控开关 键值对配置文件支持 国际化支持 让我们看看它...

    eweb4j

    eweb4j

    eweb4j最新版本src[附带需要的jar]

    eweb4j 最新的src 需要的jar包也都在其中. 可以读eweb4j的源代码 不必在网页上那样麻烦

    1756-eweb手册

    Rockwell 1756-Eweb模块

    eWeb editor编辑器文件

    eWeb editor编辑器文件,说明,使用方法:将解压后的editor文件夹拷贝到项目根目录下,在需要的页面中加入以下内容: 办事内容:&lt;/font&gt;&lt;/td&gt; ;style=s_blue" frameborder="0" width="99%" ...

    eweb编辑器(带图片上传功能)

    ASP常用的后台编辑器,带图片上传功能 调用方法如下例子: &lt;textarea name="nr" ROWS="20" COLS="70"&gt;%=Server.HTMLEncode(rs("nr"))%&gt;&lt;/textarea&gt; &lt;iframe ID="eWebEditor1" src="../eWebEditor/...

    MyPHP Explorer(Web文件在线管理) 修改版.rar

    多文件的上载 E. 文本型文件(.php, .html, .txt 等)的编辑 F. 图片及 falsh 文件的即时浏览 G. 文件下载  新增功能: H.多媒体编缉文件(绑定EWEB、FCKeditor) I.非空目录删除(带有子目录或文件) ...

    LSI-SAS-RAID卡命令行操作手册

    LSI-SAS-RAID卡提升操作指南,LSI-SAS-RAID的操作手册,可以参照学习命令行的方式

    一个很好的eweb编辑器

    eweb编辑器 要改下db中的后缀为asp

    eweb编辑器,shengcheng

    在线编辑HTML,使用户方便使用编码在线编辑HTML,使用户方便使用编码

    eWeb7.3.0 商业版 支持上传版 在线html编辑器

    eWeb 7.3.0 商业版 支持上传版 在线html编辑器

    在线编辑器(eweb)应用实例

    在线编辑器应用实例,方便大家学习,有完整的数据库和调用过程,参数说明说细

    eWebArticle(极限文章管理系统) v1.0(Net)

    eWebArticle可自定义的批量文件生成大大提高了静态模式的生成效率,您可以根据您的服务器资源情况相应的设置一次生成的文章数,生成时间大大缩断。 4、无限级分类: eWebArticle支持无限级的文章分类,您可以自由...

    eWEB - literate programming in AsciiDoc-开源

    让 AsciiDoc 成为您的文学编程工具集的一部分。 使用 eWEB,您可以使用嵌入的 WEB 代码片段编织和缠结作为 AsciiDoc 文档编写的文字程序。

    免费友情链接网自动收录

    4.特别提醒所有客户,网站上传后一定要修改data下在数据库名(改了数据库名,要改conn.asp和adminmaster/conn.asp和iP/conn.asp)! 5.后台管理地址也建议修改,就是将adminmaster目录改名! 后台管理地址adminmaster ...

    Goby 最全最新POC共计448个

    CNVD-2021-00876、Weblogic LDAP 远程代码执行漏洞 CVE-2021-2109、XXL-JOB 任务调度中心 后台默认弱口令、帆软报表 v8.0 任意文件读取漏洞 CNVD-2018-04757、锐捷NBR路由器 EWEB网管系统 远程命令执行漏洞、蜂网...

    eweb:网站是“ eWEB”项目的一部分

    eWEB - 对手,Emmanuel Carrère 该网站是作为我们 eWEB 项目的一部分创建的,其目的是创建一个文化站点。 我们的选择落在了 Emmanuel Carrère 的《对手》一书中。 然后我们决定创建一个互联网站点,该站点涉及...

    eweb.rar_eweb_editor

    ewebeditor2.80最终版,绝对好用

    Python库 | eweb-0.0.3.tar.gz

    资源分类:Python库 所属语言:Python 资源全名:eweb-0.0.3.tar.gz 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059

    e-web editor 3.8

    eweb editor 3.8完整中文版

Global site tag (gtag.js) - Google Analytics