文档章节

用 Hasor 实现文件上传

哈库纳
 哈库纳
发布于 2016/10/06 13:14
字数 622
阅读 169
收藏 0

    Hasor 采用了与 JFinal 类似的方式提供 API,底层的上传机制是来自 apache commons fileupload 并将其进行大量简化后内置到 Hasor 自身。

    因此在 Hasor 中使用文件上传功能无需引入任何第三方 jar 包您就可以使用该功能,先从一个简单的例子说起。

@MappingTo("/fileupload.do")
public class FileupLoad extends WebController {
    public void execute() throws IOException {
        FileItem multipart = this.getOneMultipart("upfile");
        multipart.writeTo(...);
        multipart.deleteOrSkip();
    }
}

    而对应的 html 页面就是一个普通的 文件表单上传。

<form action="/fileupload.do" method="post" enctype="multipart/form-data">
    <input type="file" name="upfile"/>
    <input type="submit" value="上传"/>
</form>

    大一点的文件,在上传时服务器需要一个临时存储。使用 Hasor 上传文件你可以在解析上传时指定临时存储目录,也可以使用 Hasor 环境变量中指定的默认上传地址。默认情况下 Hasor 使用默认位置进行缓存上传数据。

缓存目录

    下面是两种上传方式,第一种是用了 Hasor 默认自带的缓存目录配置。而第二种方式是用户自定义上传的缓存目录和配置信息。

@MappingTo("/fileupload.do")
public class FileupLoad extends WebController {
    public void execute() throws IOException {
        //
        // 方式1: - 使用默认缓存目录
        FileItem multipart = this.getOneMultipart("upfile");
        multipart.writeTo(new File(""));
        multipart.deleteOrSkip();
        //
        // 方式2: - 使用自定义缓存目录
        String cacheDirectory = "...";
        Integer maxPostSize = 1024 * 1024;
        FileItem multipart1 = this.getOneMultipart("upfile", cacheDirectory, maxPostSize);
    }
}

    而在接下来将会介绍一下 Hasor 默认的上传缓存配置。

    临时上传缓存的配置信息保存在:“hasor.fileupload.cacheDirectory”配置项下。这个配置位于 hasor jar 包中的“static-config.xml”配置文件中。具体内容如下:

...
<hasor>
    ...
    <!-- 文件上传 -->
    <fileupload>
        <!-- 上传文件缓存目录 -->
        <cacheDirectory>${HASOR_TEMP_PATH}/fragment</cacheDirectory>
        <!-- 允许的请求大小 ( -1 表示不限制)-->
        <maxRequestSize>-1</maxRequestSize>
        <!-- 允许上传的单个文件大小( -1 表示不限制) -->
        <maxFileSize>-1</maxFileSize>
    </fileupload>
    ...
</hasor>
...

    在这段配置文件中 “HASOR_TEMP_PATH” 表示的是一个环境变量,在 static-config.xml 配置文件的 “environmentVar” 节点下可以找到这个环境变量的内容。

<environmentVar>
    ...
    <!-- 工作目录 -->
    <WORK_HOME>%USER.HOME%/hasor-work</WORK_HOME>
    <!-- 临时文件位置 -->
    <HASOR_TEMP_PATH>%WORK_HOME%/temp</HASOR_TEMP_PATH>
    ...
</environmentVar>

    默认情况下 “HASOR_TEMP_PATH” 的配置信息是 “%WORK_HOME%/temp”,我们看到这又是一组环境变量。“WORK_HOME” 默认情况下表示的是 “USER.HOME”。而这是用户登录系统之后的用户主目录。

    如果您是 linux 系统那么这个目录通常在这里:“/home/xxx”,如果是 window 用户用户住目录会在“c:/users”下面。

© 著作权归作者所有

共有 人打赏支持
哈库纳

哈库纳

粉丝 965
博文 84
码字总数 151810
作品 4
杭州
后端工程师
私信 提问
Hasor 2.4.4 发布,宽泛的Servlet版本,以及内置文件上传

===== Hasor-Core v2.4.4 (2016-09-05) 新增: 改进: 亮点一: 新增文件上传支持,使用 Hasor 的文件上传不需要引入任何 Jars。Hasor 将大名鼎鼎的 apache fileupload 框架进行了大量优化之后集...

哈库纳
2016/09/05
81
0
使用 Hasor 实现 模版化配置文件

Hasor 不光小巧还很精良,这一片文章我们来讲一讲 “模版化配置文件”。 首先在了解模版化配置文件之前先看一下我们的实际开发中的问题。现在假设你有一个小团队,大家分别开发同一个项目的不...

哈库纳
2016/10/06
137
0
Hasor 2.4.4 发布,宽泛的Servlet版本内置文件上传

亮点一: 新增文件上传支持,使用 Hasor 的文件上传不需要引入任何 Jars。Hasor 将大名鼎鼎的 apache fileupload 框架进行了大量优化之后集成到自身内部。 宽泛的文件上传Api支持,支持流式上...

哈库纳
2016/09/05
953
2
Hasor-Core v0.0.1 发布

Hasor-Core v0.0.1.Release 01.)Hasor-Core:80%以上代码重构,重构主要涉及内容的是结构性重构。重构之后更便于扩展核心层功能。 1.InitContext接口功能合并到Environment接口中。 2.ApiBin...

哈库纳
2013/09/18
320
0
Hasor 的 Xml 配置文件解析详解

我觉得 Xml 作为配置文件最大的好处是结构化,对程序配置信息可以有结构有组织的进行描述。但是使用 Xml 作为配置文件带给我们的问题是我们需要程序自己去解析Xml配置文件结构。这显得有点多...

哈库纳
2013/12/31
0
4

没有更多内容

加载失败,请刷新页面

加载更多

CentOS配置Tomcat监听80端口,虚拟主机

Tomcat更改默认端口为80 更改的配置文件是: /usr/local/tomcat/conf/server.xml [root@test-a ~]# vim /usr/local/tomcat/conf/server.xml # 找到 Connector port="8080" protocol="HTTP/1......

野雪球
29分钟前
2
0
《稻盛和夫经营学》读后感心得体会3180字范文

《稻盛和夫经营学》读后感心得体会3180字范文: 一代日本经营之圣稻盛和夫凭借刻苦勤奋的精神以及深植于佛教的商业道德准则,成为了“佛系”企业家的代表人物。在《稻盛和夫经营学》“领导人...

原创小博客
今天
1
0
java框架学习日志-5(常见的依赖注入)

依赖注入(dependency injection) 之前提到控制反转(Inversion of Control)也叫依赖注入,它们其实是一个东西,只是看的角度不同,这章详细说一下依赖注入。 依赖——指bean对象创建依赖于...

白话
今天
2
0
红外接收器驱动开发

背景:使用系统的红外遥控软件没有反应,然后以为自己接线错误,反复测试,结果烧坏了一个红外接收器,信号主板没有问题。所以自己开发了一个红外接收器的python驱动。接线参见https://my.os...

mbzhong
今天
2
0
ActiveMQ消息传送机制以及ACK机制详解

AcitveMQ是作为一种消息存储和分发组件,涉及到client与broker端数据交互的方方面面,它不仅要担保消息的存储安全性,还要提供额外的手段来确保消息的分发是可靠的。 一. ActiveMQ消息传送机...

watermelon11
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部