学生申请学科竞赛活动,表单中有学科竞赛的申报信息和部分附件,需要做到将上传文件和表单数据提交保持一致性。

将上传文件和插入表单数据放到事务汇总去处理,由于表单的数据我们可以控制,但是上传的文档不好控制。一方面我就把表单数据提交放置在文件上传前面,这样当表单数据提交发生异常我们可以回滚,文件并未上传,当文件上传发生异常时,我们可以回滚数据库的数据,只有当文件正常上传时我们才提交数据库数据。。。

---------------------------------------------------------------------------------------------------------------------------------------

 1     @Override
2 public boolean applActivity(XkTeam team, Document doc, DocType doctype,
3 FileInputStream fin) {
4
5 boolean flag = true;
6 FileOutputStream fos = null;//文档输出流
7 // ------------处理需要向数据库提交的文档、文档类型及申报信息--------------------
8 // 开启事务,设置不自动提交
9 JDBCTools.startTransaction();
10
11 try {
12 // 判断是个人申报还是团体申报调用不同的方法
13 // 个人申报
14 if (team.getAppType() == 0) {
15
16 flag = idao.addPersonApp(team);
17 //更新当前申报人数
18 flag = idao.updateCurrentNum(team.getAppType(),1);
19 }
20
21 // 团体申报
22 if (team.getAppType() == 1) {
23
24
25 flag = idao.addTeamInfor(team);
26 flag = idao.addTeamMember(team.getMemberlist());
27 //更新当前申报人数
28 flag = idao.updateCurrentNum(team.getActiId(), team.getMemberlist().size());
29 }
30
31 if(doc != null && doctype != null){ //处理用户是否上传文档
32 // 调用dao层插入文件的方法
33 flag = idao.addDocument(doc);
34 // 调用dao层插入文件类型方法
35 flag = idao.addDocType(doctype);
36
37 // ---------------处理上传文档------------
38 // 1.创建上传文档File
39 File file = new File(doc.getDoc_path());
40 // 2.创建写文档对象
41 fos = new FileOutputStream(file);
42 // 3.创建缓冲流
43 byte[] buffer = new byte[1024];
44 int len = 0;
45 while ((len = fin.read(buffer)) > 0) {
46 // 写入文件
47 fos.write(buffer, 0, len);
48 }
49 }
50 // 提交
51 JDBCTools.commit();
52 } catch (Exception e2) {
53 e2.printStackTrace();
54 // 发生异常回滚
55 JDBCTools.rollback();
56 throw new RuntimeException("申报失败,请联系管理员!", e2);
57 } finally {
58 // 关闭资源
59 JDBCTools.setCommitTrue();
60 JDBCTools.close();
61
62 if(fos != null){
63 try {
64 fos.close();
65 } catch (IOException e) {
66 e.printStackTrace();
67 }
68 }
69 }
70
71 return flag;

Java中上传文件和表单数据提交如何保持数据的一致性?的更多相关文章

  1. el-upload上传文件和表单一起提交+后端接收代码

    目录 一.前言 二.前端页面展示 三.表单代码 四.Data部分 五.JS方法 六.后端接收方式 七.总结 一.前言 我们在做前端时,会遇到这样的需求,上传Excel文件,并且还要和填写的表单数据,一 ...

  2. 谈谈php中上传文件的处理

    这是一个表单的时代... 我们在浏览器中编辑自己的信息,会遇到上传头像:在文库中,我们会上传文档......到处存在“上传”这个词. php是最好的语言(其他语言的程序猿们不要打我...).php在处 ...

  3. 为什么上传文件的表单里要加个属性enctype

    为什么上传文件的表单里要加个属性enctype 上传文件的表单中<form>要加属性enctype="multipart/form-data",很多人只是死记硬背知道上 ...

  4. Java上传文件FTP服务器代码

    1. 在实际的应用重,通常是通过程序来进行文件的上传. 2. 实现java上传文件到ftp服务器中 新建maven项目 添加依赖 <dependency> <groupId>c ...

  5. java 上传文件到 ftp 服务器

    1.  java 上传文件到 ftp 服务器 package com.taotao.common.utils; import java.io.File; import java.io.FileInpu ...

  6.  为什么上传文件的表单里要加个属性enctype----摘录

    上传文件的表单中<form>要加属性enctype="multipart/form-data",很多人只是死记硬背知道上传表单要这么写,知其然而不知其所以然.那到底为什 ...

  7. 【ASP.NET 问题】System.InvalidOperationException: 对象的当前状态使该操作无效 【大量表单数据提交】错误解决

    出现的问题描述: 当页面的数据量比较大时,出现异常,详细信息: System.InvalidOperationException: 对象的当前状态使该操作无效 问题的原因:出现这个异常的原因是因为微软 ...

  8. django(7)modelform操作及验证、ajax操作普通表单数据提交、文件上传、富文本框基本使用

    一.modelForm操作及验证 1.获取数据库数据,界面展示数据并且获取前端提交的数据,并动态显示select框中的数据 views.py from django.shortcuts import ...

  9. java上传文件,提交表单必须要设置enctype="multipart/form-data"

    表单中enctype="multipart/form-data"的意思,是设置表单的MIME编码.默认情况,这个编码格式是application/x-www-form-urlenc ...

随机推荐

  1. Spring MVC+Mybatis 执行存储过程,使用Map进行参数的传递

    研究了一天mybatis如何执行存储过程,基本了解了ORM的设计思想,在map层面进行对象关系映射有两种思路. 根据不同的业务使用不同的思路: 一.实体类和数据库映射,就是将数据库中的字段和java实 ...

  2. oc set/get方法

    新建一个“Cocoa Touch Class”文件,命名为People People.h 写入 @interface People : NSObject @property int age; @end ...

  3. 套接字I/O超时设置方法和用select实现超时

    注:如无特殊说明,sockfd 原始状态都是阻塞的. 一.使用alarm 函数设置超时  C++ Code  1 2 3 4 5 6 7 8 9 10 11 12 13   void handler( ...

  4. Dev BarManager使用方法

    作者:jiankunking 出处:http://blog.csdn.net/jiankunking 近期使用BarManager时候.发现一个问题就是在一開始把BarManager控件拖到窗口上的时 ...

  5. WIN7下恼人的AppData——删除没用的缓存文件

    今日.打开电脑,发现C盘可用容量居然变得非常小.认为非常是可疑,例如以下图所看到的: 最初的反应是电脑中毒了,于是使用360卫士.360杀毒对C盘查杀,由于明明记得C盘有40多G的可用空间才对.出现这 ...

  6. C#--类成员

    数据成员: 字段: 常量: 函数成员(执行代码): 方法: 属性 构造函数 析构函数 运算符 索引 事件 可以被声明为Static的类成员是:

  7. Visual Studio Code 调试 nodejs (断点调试、自动重启、进程调试)

    学习链接: https://cnodejs.org/topic/5a9661ff71327bb413bbff5b https://github.com/nswbmw/node-in-debugging ...

  8. python标准库介绍——5 re模块详解

    == re 模块== "Some people, when confronted with a problem, think 'I know, I'll use regular expres ...

  9. CSS选择器、层叠相关的基础知识

    CSS是Cascading Style Sheets的英文缩写,即层叠样式表.CSS2.1是W3C于2007年发布,现在推荐使用的.CSS3现在还处于开发中,有部分浏览器的新版本支持. 1. CSS ...

  10. 使用Frame控件设计Silverlight的导航

    这里所说的导航其实就是在Silverlight的页面之间前进后退以及跳转.通过Frame控件配合后台NavigationService类可以很容易的做到页面之间的导航. 这就是工具箱中的Frame控件 ...