package etcom.servlet;

 import java.io.File;
import java.io.IOException;
import java.sql.Connection;
import java.util.ArrayList;
import java.util.List; import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;
import org.apache.commons.lang.StringUtils;
import org.json.JSONArray;
import org.json.JSONObject; import etcom.servlet.DBUtil;
import etcom.servlet.SqlActuator; @SuppressWarnings("serial")
public class Execute extends HttpServlet { public Execute() {
super();
} public void destroy() {
super.destroy(); // Just puts "destroy" string in log
// Put your code here
} public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setCharacterEncoding("utf-8");
// String tr = IoToJsonUtils.getIoToJson(request, "UTF-8");
// System.out.println(tr);
String vcRes = "";
String detectTaskJOSN = "";
List<String> sqls = new ArrayList<String>();
Connection conn = DBUtil.getConnection();
SqlActuator sa = new SqlActuator(conn);
try{
String basePath = request.getSession().getServletContext().getRealPath("/");
String filePath = "../images/androidFiles/";
String filename = "";
File file0 =new File(basePath + filePath);
if(!file0.exists()&&!file0.isDirectory())file0.mkdirs();
DiskFileItemFactory factory = new DiskFileItemFactory();
factory.setRepository(file0);
//设置 缓存的大小
factory.setSizeThreshold(1024*1024);
//文件上传处理
ServletFileUpload upload = new ServletFileUpload(factory);
String encoding = request.getCharacterEncoding();
upload.setHeaderEncoding(encoding);
@SuppressWarnings("unchecked")
List<FileItem> list = (List<FileItem>)upload.parseRequest(request);
for(FileItem item : list){
//获取属性名字
String name = item.getFieldName();
//如果获取的 表单信息是普通的 文本 信息
if(item.isFormField()&&"detectTaskJOSN".equals(name)){
//获取用户具体输入的字符串,因为表单提交过来的是 字符串类型的
detectTaskJOSN = new String(item.getString(encoding));
System.out.println("detectTaskJOSN的值:"+detectTaskJOSN);
}else{
if(StringUtils.isNotEmpty(name)){
//获取路径名
String value = item.getName();
//索引到最后一个反斜杠
int start = value.lastIndexOf("\\");
//截取 上传文件的 字符串名字,加1是 去掉反斜杠,
filename = value.substring(start+1);
File file1 =new File(basePath + filePath + filename);
if(file1.exists())file1.delete();
//写到磁盘上
item.write(file1);//第三方提供的
System.out.println("上传成功:"+filename);
}
}
}
JSONObject joTask = new JSONObject(detectTaskJOSN);
String _vcTaskNo = joTask.get("vcTaskNo").toString();
String _vcUserId = joTask.get("vcUserId").toString();
String _vcEquipCode = joTask.get("vcEquipCode").toString();
String _vcEquipType = joTask.get("vcEquipType").toString();
String _vcStatus = joTask.get("vcStatus").toString();
String _vcMemo = joTask.get("vcMemo").toString();
String _dtScan = joTask.get("dtScan").toString();
String _dtHandle = joTask.get("dtHandle").toString();
String _vcHandleFlag = joTask.get("vcHandleFlag").toString();
String _vcHandleMemo = joTask.get("vcHandleMemo").toString();
String _vcHandler = joTask.get("vcHandler").toString();
String _nTypeId = joTask.get("nTypeId").toString();
String _nOid = joTask.get("nOid").toString();
String _nCodeId = joTask.get("nCodeId").toString();
String sql = " exec proc_detecttask_add '" + _vcTaskNo + "','" +
_vcUserId + "','" + _vcEquipCode + "','" + _vcEquipType +
"','" + _vcStatus + "','" + _vcMemo + "','" +
filename + "','" + _dtScan + "','" + _dtHandle +
"','" + _vcHandleMemo + "'," + _vcHandleFlag + ",'" +
_vcHandler + "'," + _nTypeId + "," + _nOid + "," +
_nCodeId;
System.out.println(sql);
sqls.add(sql); JSONArray jaDicts = new JSONArray(joTask.get("jaDicts").toString());
for(int idx = 0; idx < jaDicts.length(); idx++){
JSONObject joDict = (JSONObject)jaDicts.get(idx);
String _vcDetectInfo = joDict.get("vcDetectInfo").toString();
String _vcDetectValue = joDict.get("vcDetectValue").toString();
String _vcUnit = joDict.get("vcUnit").toString();
sql = "Insert Into T_DetectTask_Detail(vcTaskNo,vcDetectInfo,vcDetectValue,vcUnit) values ('" +
_vcTaskNo +
"','" +
_vcDetectInfo +
"','" + _vcDetectValue + "','" + _vcUnit + "')";
System.out.println(sql);
sqls.add(sql);
}
sa.batchExec(sqls);
vcRes = "{\"vcRes\":\"success\"}";
}catch(Exception e){
e.printStackTrace();
vcRes = "{\"vcRes\":\"fail\"}";
}finally{
DBUtil.close(null, null, conn);
response.getWriter().println(vcRes);
}
} public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { doGet(request, response);
} public void init() throws ServletException {
// Put your code here
}
}

Android、iOS与Servlet接口上传文件和JSON串的交互的更多相关文章

  1. Servlet异步上传文件

    这里需要用到插件ajaxfileupload.js,jar包:commons-fileupload-1.3.2.jar,commons-io-2.5.jar 注意红色部分的字!!!! 1.创建一个we ...

  2. Flex和Servlet结合上传文件

    Flex和Servlet结合上传文件 1.准备工作 (1)下载文件上传的组件,commons-fileupload-1.3.1.jar (2)下载文件输入输出jar,commons-io-2.4.ja ...

  3. 使用python或robotframework调multipart/form-data接口上传文件

    这几天调一个multipart/form-data类型的接口,遇到点小阻碍.之前同事有使用urllib库写了个类似的方法实现,比较长,想要改的时候发现不太好使.在网上查找发现用requests库做这个 ...

  4. Servlet 实现上传文件以及同时,写入xml格式文件和上传

    package com.isoftstone.eply.servlet; import java.io.BufferedReader; import java.io.BufferedWriter; i ...

  5. Java Servlet 接收上传文件

    在Java中使用 Servlet 来接收用户上传的文件,需要用到两个apache包,分别是 commons-fileupload 和 commons-io 包: 如果直接在doPost中,使用requ ...

  6. Android通过HTTP协议实现上传文件数据

    SocketHttpRequester.java package cn.itcast.utils; import java.io.BufferedReader; import java.io.Byte ...

  7. Android应用开发中webview上传文件的几种思路

    1. 常规方法,重写WebChromeClient 的 openFileChooser 方法 private class MyWebChromeClient extends WebChromeClie ...

  8. 使用RestTemplate调用接口上传文件

    场景 接口接受一个文件,缓存在本地,验证文件的完整性及内容,然后将文件上传至云服务器: 下面只写利用RestTemplate将文件上传至云服务器,至于文件上传以及缓存在本地可以参考:JAVA文件上传: ...

  9. java 调用Spring接口上传文件及其他参数填充

    第一步:在Spring配置中添加以下内容 <!-- 配置MultipartResolver 用于文件上传 使用spring的CommosMultipartResolver --> < ...

随机推荐

  1. ansible笔记(2):管理清单配置详解

    前情提要:管理清单(Iventory)配置文件/etc/ansible/hosts.通过修改该配置文件以达到管理受控主机的目的.    在我的实验平台上有3台主机:192.168.232.181(an ...

  2. 为什么CSS,JS以及图片等这些资源的路径需要加问号

    我们平时练习的时候,很少写路径上面需要加问号的,而实际应用当中,我们经常看到一些资源的路径后面跟着问号,这是为什么呢? 答:答案很简单哦,其实就是为了防止缓存,我们可以在原本路径的后面加上问号,加上我 ...

  3. form表单提交且接口回调显示提交成功

    前端: <form method="post" enctype="multipart/form-data" id="formSubmit&quo ...

  4. poj 3057(bfs+二分匹配)

    题目链接:http://poj.org/problem?id=3057 题目大概意思是有一块区域组成的房间,房间的边缘有门和墙壁,'X'代表墙壁,'D'代表门,房间内部的' . '代表空区域,每个空区 ...

  5. Redis06——Redis五大数据类型 list

    list 单键多值 Redis列表是简单的字符串列表,按照插入顺序排序,可以添加左边/右边 底层实际上是一个双向链表,对两端的操作性能好,但是通过索引下标的操作中间节点性能较差  lpush/rpus ...

  6. Redis04——Redis五大数据类型 key

    key  keys *  查看当前库的所有键  exists <key>  判断某个键是否存在  type <key>   查看键的类型  del<key>  删除 ...

  7. 第十九篇 vim编辑器的使用技巧

    vim编辑器 ~/.viminfo文件中存储了vim编辑器中常用的命令 vim编辑器共有3中模式:命令模式.末行模式和输入模式,三种模式的转换方式如下图所示: vim 文件名      # 编辑一个文 ...

  8. 【StarUML】时序图

    时序图是可视化地展示对象与对象之间的联系的图,与其他的图相比,它跟侧重于表现为了完成一个用例,对象之间是怎么协同工作的. 之前学习的组件图.用例图都能表现对象之间的联系,侧重的是"有哪些联系 ...

  9. select2多选框初始化默认值和获得值

    select2多选自带手动输入搜索功能,可怜我还查寻半天api 获得值: //chang函数获取选择的option $(".js-example").change(function ...

  10. HyperLedger Fabric 资料网址大全

    BLOCKCHAIN FOR DEVELOPERS 官方网址 i. 这个网址是ibm给的测试网址,注册进去就可以设置4个节点的区块链,而且有智能合约可以测试 区块链和HyperLedger开源技术讲堂 ...