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

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

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

 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=&quot;multipart/form-data&quot;

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

随机推荐

  1. 开源组件ExcelReport 1.5.2 使用手册

    ExcelReport是一款基于NPOI开发的报表引擎组件.它基于关注点分离的理念,将数据与样式.格式分离.让模板承载样式.格式等NPOI不怎么擅长且实现繁琐的信息,结合NPOI对数据的处理的优点将E ...

  2. 113、ScrollView滑动到了最底部

    ScrollView使用 http://www.cnblogs.com/androidsj/archive/2012/03/04/2379387.html 滚动到顶部判断:getScrollY() = ...

  3. Android 获取信号强度

    大 家看到标题就明白了,我们有的时候在电梯里,有时有的电话有信号,有时有的电话没有信号,这个是非常闹心的,要是我们能监听一下我们自己手机信号的强度就 好了.这样,当我们在等重要的人士的电话,不至于接不 ...

  4. 使用MFC读写Excel

    _Application m_ExlApp;   //组件服务器的各个classes     _Workbook m_ExlBook;     Workbooks m_ExlBooks;     _W ...

  5. libc++abi.dylib: terminate_handler unexpectedly threw an exception错误小结

    说法一: 我们在运行xcode工程时,有时候会遇到”libc++abi.dylib: terminate_handler unexpectedly threw an exception”错误,app莫 ...

  6. [阿里云部署] Ubuntu+Flask+Nginx+uWSGI+Mysql搭建阿里云Web服务器

    部署地址:123.56.7.181 Ubuntu+Flask+Nginx+uWSGI+Mysql搭建阿里云Web服务器 这个标题就比之前的"ECS服务器配置Web环境的全过程及参考资料&qu ...

  7. Redis --&gt; Redis架构设计

    Redis架构设计 一.前言   Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间件. 它支持多种类型的数据结构,如 字符串(strings), 散列 ...

  8. 【读书笔记】iOS-软件测试与iOS测试

    一,软件测试的类型. 1.软件测试按照测试类型,可以划分为:单元测试,集成测试和系统测试. 2.单元测试是指对软件系统中最小可测试单元进行的检查和验证. 3.集成测试,在iOS软件开发中,集成测试主要 ...

  9. spring-data-jpa与mybatis的对比

    Spring Data JPA 与 MyBatis对比 Spring Data JPA是Spring Data的子模块.使用Spring Data,使得基于“repositories”概念的JPA实现 ...

  10. JavaScript oop proto与prototype原型图

    [_proto_与prototype] 1.prototype(函数的原型):函数才有prototype.prototype是一个对象,指向了当前构造函数的引用地址. 2._proto_(对象的原型对 ...