近期。项目里面用到了Jfinal 里面的上传附件。

Jfinal 的Controller 里面提供了一个 getFile系列方法提供文件上传。

我这里呢,是文件上传和表单參数一起提交。

页面类似下图:

这里form表单里面使用了 enctype="multipart/form-data" 。

先看看Jfinal手冊的说明吧!大家看了就知道了

然后还有个问题 假设是表单提交 还不能够用ajax 提交,详细的原因呢也找到了 http://www.oschina.net/question/941098_93842

这个就是为什么不能够使用ajax 提交了的原因。

然后我们能够在页面里面 这样提交

方法一:

function tosave(){
var data = $("#表单id").serialize();
$("#<span style="font-family: Arial, Helvetica, sans-serif;">表单id</span>").attr("action","equipment/saveOrUpdate?"+data);//跳到指定的contronller
$("#表单id").submit();//提交
};

在提交button设置一个 onclick 事件。这样我们就把前台的表单里面的 A,B,C,D...等參数 我们就能够提交到后台了!

后台代码:

UploadFile file = getFile("filedata", path, 200 * 1024 * 1024, "UTF-8");//上传文件 而且获取表单參数

好。到这里基本文件上传和表单里面的參数 我都能够获取到了。以往在这里 我们都是保存成功后 提示保存成功。而且刷新页面。

可是这里我们没有返回值,或许你能够说你能够重定向或是转发啊。

额,我仅仅想说我这里的需求就是提示保存成功。而且刷新列表页面,或是提示保存失败,

也相同要刷新页面。

so ..我就找了另外一种方法提交

$('#表单id').ajaxForm({
target:'#output1',
iframe:true,
url : 'abc/saveOrUpdate',
beforeSubmit: function (){
var filename = $("input[name='filedata']").val();
// alert($("#equ_no").val());
// alert(filename);
// if(filename.EndWith(".png") || filename.EndWith(".jpg")
// || filename.EndWith(".jpeg")|| filename.EndWith(".ico")){
// return window.confirm("确定要处理此文件吗? ");
// }else{
// alert("请上传图片文件!");
// return false;
// }
}
});

这里用的是jquery 表单插件ajaxForm 详细使用方法去百度,我也是赶猪上架。

好吧 继续看 我改进了的后台 部分代码

String message = "操作错误";
String result = Setting.OPTION_FAILUE;
<span style="font-family: Arial, Helvetica, sans-serif;">UploadFile file = getFile("filedata", path, 200 * 1024 * 1024, "UTF-8");//上传文件 而且获取表单參数</span>

this.setAttr("result", result);
this.setAttr("message", message);
this.renderHtml("<script>parent.showResponse('"+result+"','"+message+"')</script>");

有木有发现 这里的renderHtml就类似 之前的 rendJson();

这后面的 代码 有的涉及到了 其它地方 所以我就选了一下 相关的出来,大家能够看看这个思路。写作水平有限。请勿喷~

[学习笔记]--Jfinal 表单提交附件的更多相关文章

  1. 20151223jquery学习笔记--Ajax表单提交

    传统的表单提交, 需要多次跳转页面, 极大的消耗资源也缺乏良好的用户体验. 而这款form.js 表单的 Ajax 提交插件将解决这个问题.一. 核心方法官方网站: http://malsup.com ...

  2. SpringMVC学习笔记:表单提交 参数的接收

    SpringMVC可以接收原生form表单和json格式数据 有一个名为Book的model,其中的属性如下: 字符串类型的name,数字类型的price,数组类型的cover,集合类型的author ...

  3. AngularJS 1.2.x 学习笔记(表单校验篇)

    https://my.oschina.net/cokolin/blog/526911 摘要: 本文首发于 blog.csdn.net/vipshop_ebs/article/details/39472 ...

  4. Bootstrap学习笔记(二) 表单

    在Bootstrap学习笔记(一) 排版的基础上继续学习Bootstrap的表单,编辑器及head内代码不变. 3-1 基础表单 单中常见的元素主要包括:文本输入框.下拉选择框.单选按钮.复选按钮.文 ...

  5. Symfony2学习笔记之表单

    对于一个Web开发者来说,处理HTML表单是一个最为普通又具挑战的任务.Symfony2集成了一个Form组件,让处理表单变的容易起来.在这一节里,我们将从基础开始创建一个复杂的表单,学习表单类库中最 ...

  6. [知了堂学习笔记]_Jquery_Validate 表单校验的使用

    一.效果图: 二.JqueryValidate的好处 在做注册.或者类似以上的表单提交的时候,大家是不是都很烦那种,把数据拿到后台去判断, 可能经过了正则表达式之类的复杂判断,然后发现数据错误.接着通 ...

  7. php学习笔记-获取表单数据

    在网页上经常要填写用户名和密码,点击确认按纽之后,用户名和密码经过前端处理之后发送到了服务器上,那么服务器端怎么获取到这些用户提交的数据呢?就是通过超级全局变量 _POST和_GET 先拿_POST做 ...

  8. vue学习笔记(六)表单输入绑定

    前言 在上一章vue学习笔记(四)事件处理器这一篇博客的内容中,我们已经了解vue是如何绑定事件的,而本篇博客主要讲解的是vue中表单输入的绑定,通常我们自己提交信息的时候都是通过表单将信息到服务器的 ...

  9. PHP再学习1——cURL表单提交、HTTP请求和响应分析

    1.前言 最近迷恋WEB方面的技术,虽然自己是一个嵌入式工程师,但是我深知若需要把传感器终端的数据推送至“平台”必然会和WEB技术打交道.在工作中发现嵌入式工程师喜欢 二进制形式的协议,例如MODBU ...

随机推荐

  1. 实现SELECT的全选,反选,AB选的JAVASCRIPT代码

    参考网上,用原生JS粗糙实现. 我发现用UIKIT的BUTTON会自动刷新我那核心的模态窗口,只好用另外的LABEL或CODE标签了. $(".btn-select-all").c ...

  2. POJ2225+BFS

    简单的BFS   1a /* 从起点到终点 */ #include<stdio.h> #include<string.h> #include<stdlib.h> # ...

  3. 物理地址为20位 如10000H 用段地址*16+偏移地址表示

    段地质在cpu中,为16位 段地质*16则变成物理首地址20位,这个物理首地址必定是16的倍数. 偏移地址16位, 则表明一个段的大小为64k. 同时也表明16位地址的寻址能力为64kb

  4. mac 浏览器 强刷快捷键

    windows 浏览器的刷新快捷键F5,强制刷新Ctrl+F5 Mac 系统下浏览器的刷新快捷键 command+R, 强制刷新快捷键为 command+shift+R

  5. 《ArcGIS Engine+C#实例开发教程》第四讲 状态栏信息的添加与实现

    原文:<ArcGIS Engine+C#实例开发教程>第四讲 状态栏信息的添加与实现 摘要:在上一讲中,我们完成了 MapControl 和PageLayoutControl两种视图的同步 ...

  6. com.google.common.eventbus.EventBus介绍

    以下内容直接翻译了EventBus的注释: com.google.common.eventbus.EventBus介绍: 首先这个类是线程安全的, 分发事件到监听器,并提供相应的方式让监听器注册它们自 ...

  7. js模拟Map对象,实现key---value

    js模拟Map对象,实现key---value 根据java中map的属性,实现key----value保存 function Map() { var struct = function (key, ...

  8. Windows中APACHE开启fastcgi后无法连接数据库

    环境:Windows server 2003 x64Apache 2.2.14mod_fcgid-2.2b-w32.zipPHP VC9 x86 Non Thread Safe(用Visual C++ ...

  9. CodeBlocks+opencv2.4.4+cmake+MinGW

    /*-----------------------------------------------------------------------------*   *   版权声明:*   可以任意 ...

  10. 【HTML】Advanced1:Text: Time, Mark, and "Presentational"

    1.Exploring the depths of HTML5 2.</time> <p>Written by Doctor Who on <time datetime= ...