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. Custom LED Keychain, Small And Surefire Gifts

    The    LED Keychain    makes it easy for people to carry their keys with them and carry them with th ...

  2. nmonchart 分析.nmon监控数据成html展示

    下载地址:http://nmon.sourceforge.net/pmwiki.php?n=Site.Nmonchart chart安装包:http://sourceforge.net/project ...

  3. JS高级---为内置对象添加原型方法

    为内置对象添加原型方法 我们能否为系统的对象的原型中添加方法, 相当于在改变源码   我希望字符串中有一个倒序字符串的方法 //我希望字符串中有一个倒序字符串的方法 String.prototype. ...

  4. luckyframe的一些坑

    建议使用idea运行 1.第一次运行访问http://localhost:8088/LuckyFrameServer 2.luckyframe提示“javax.net.ssl.SSLKeyExcept ...

  5. 简单json 转换为 map、对象

    1.如果转换的是Map.或者是简单的对象 package com.gc.action; import java.util.Map; import net.sf.json.JSONObject; /** ...

  6. Codeforces 1315C Restoring Permutation

    You are given a sequence b1,b2,…,bnb1,b2,…,bn . Find the lexicographically minimal permutation a1,a2 ...

  7. git按需过滤提交文件的一个细节

    问题场景 用git管理代码时,作为git小白的我总会遇到一些无法理解的问题,在请教了一些高手后终于解开了疑惑,参考以下场景: 1.比如我们已在电脑1上完成用vs编辑项目.添加.提交到服务器的完整流程, ...

  8. C++ explicit的作用

    explicit作用: 在C++中,explicit关键字用来修饰类的构造函数,被修饰的构造函数的类,不能发生相应的隐式类型转换,只能以显示的方式进行类型转换. explicit使用注意事项: * e ...

  9. laravel 模型观察器

    模型观察器 对模型的生命周期内的多个时间点进行监控,分别有 ~ing 和 ~ed 事件 每个监控方法接收 model 作为唯一参数 使用观察器 创建观察器文件,一个普通类,不需要继承什么 针对需要的事 ...

  10. 循环select和取赋值

    bootstrap: <!--列表容器--> <div class="panel-body" style="position:relative;&quo ...