ViewController.java 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  1. package com.zskk.control;
  2. import java.io.File;
  3. import java.io.FileOutputStream;
  4. import java.io.IOException;
  5. import java.io.InputStream;
  6. import java.text.ParseException;
  7. import java.text.SimpleDateFormat;
  8. import java.util.ArrayList;
  9. import java.util.Date;
  10. import java.util.HashMap;
  11. import java.util.Iterator;
  12. import java.util.List;
  13. import java.util.Map;
  14. import org.w3c.dom.NamedNodeMap;
  15. import org.w3c.dom.NodeList;
  16. import com.jfinal.core.Controller;
  17. import com.jfinal.kit.PropKit;
  18. import com.jfinal.plugin.activerecord.ActiveRecordPlugin;
  19. import com.jfinal.plugin.activerecord.Db;
  20. import com.jfinal.plugin.activerecord.Record;
  21. import com.jfinal.plugin.activerecord.dialect.OracleDialect;
  22. import com.jfinal.plugin.activerecord.dialect.SqlServerDialect;
  23. import com.jfinal.plugin.druid.DruidPlugin;
  24. import com.zskk.service.DataService;
  25. import com.zskk.service.ServiceFactory;
  26. import com.zskk.service.ThreadPoolService;
  27. import com.zskk.tools.ExecUtil;
  28. import com.zskk.tools.XmlHelper;
  29. import okhttp3.FormBody;
  30. import okhttp3.MediaType;
  31. import okhttp3.OkHttpClient;
  32. import okhttp3.Request;
  33. import okhttp3.RequestBody;
  34. import okhttp3.Response;
  35. public class ViewController extends Controller {
  36. private static final MediaType JSON_CODE = MediaType.get("application/json; charset=utf-8");
  37. private static final OkHttpClient OKHTTP_CLIENT = new OkHttpClient();
  38. /**
  39. * 在被连接数据库执行sql语句
  40. */
  41. public void executeSql() {
  42. try {
  43. List<Record> d = Db.use("connected").find(this.getPara("sqlstr"));
  44. this.renderJson(d);
  45. } catch (Exception e) {
  46. // TODO: handle exception
  47. this.renderText(e.toString());
  48. }
  49. }
  50. public void testConn() {
  51. try {
  52. DruidPlugin druidPluginConnected = createConnectedDruidPlugin();
  53. druidPluginConnected.start();
  54. // 配置ActiveRecord插件
  55. ActiveRecordPlugin arpConnected = new ActiveRecordPlugin("connected", druidPluginConnected);
  56. arpConnected.setDialect(new SqlServerDialect());
  57. arpConnected.start();
  58. } catch (Exception e) {
  59. // TODO: handle exception
  60. this.renderText(e.toString());
  61. }
  62. }
  63. public void testtime() {
  64. SimpleDateFormat sdf= new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  65. Date date = new Date();
  66. long dInteger =date.getTime()-360000;
  67. String daString = sdf.format(new Date(dInteger));
  68. this.renderText(daString);
  69. }
  70. public void tdln() {
  71. try {
  72. List<Record> record = Db.use("connected").find("select * from imageinfo where AccessionNumber=174777");
  73. for (Record record2 : record) {
  74. Request request = new Request.Builder()
  75. .url(record2.getStr("IMAGE_PATH"))
  76. .build();
  77. String fileName = record2.getStr("SOP_INSTANCE_UID");
  78. // String fileName = "aaaa";
  79. try (Response response = OKHTTP_CLIENT.newCall(request).execute()) {
  80. if (!response.isSuccessful())
  81. throw new IOException("Unexpected code " + response);
  82. String dirName = "/home/zskk/DICOM_URL";
  83. File file = new File(dirName);
  84. if (!file.exists()) {
  85. file.mkdir();
  86. }
  87. if (response != null) {
  88. InputStream is = response.body().byteStream();
  89. FileOutputStream fos = new FileOutputStream(new File(dirName + "/" + fileName));
  90. int len = 0;
  91. byte[] buffer = new byte[2048];
  92. while (-1 != (len = is.read(buffer))) {
  93. fos.write(buffer, 0, len);
  94. }
  95. fos.flush();
  96. fos.close();
  97. is.close();
  98. File filen2 = new File(dirName + "/" + fileName);
  99. File filen = new File(dirName + "/" + fileName+".dcm");
  100. filen2.renameTo(filen);
  101. }
  102. } catch (IOException e) {
  103. // TODO Auto-generated catch block
  104. this.renderText("1*"+e.toString());
  105. }
  106. }
  107. } catch (Exception e) {
  108. // TODO: handle exception
  109. this.renderText(e.toString());
  110. }
  111. this.renderText("succ");
  112. }
  113. public static DruidPlugin createConnectedDruidPlugin() {
  114. return new DruidPlugin(PropKit.get("jdbcUrl_connected"), PropKit.get("user_connected"),PropKit.get("password_connected").trim());
  115. }
  116. /**
  117. * post请求
  118. * @param url-请求地址
  119. * @param map-参数集合
  120. * @return
  121. */
  122. private static String doPost(String url, Map<String, String> map) {
  123. FormBody.Builder builder = new FormBody.Builder();
  124. for (String key : map.keySet()) {
  125. builder.add(key, map.get(key));
  126. }
  127. RequestBody formBody = builder.build();
  128. Request request = new Request.Builder().url(url).post(formBody).build();
  129. try (Response response = OKHTTP_CLIENT.newCall(request).execute()) {
  130. if (!response.isSuccessful()) throw new IOException("Unexpected code " + response);
  131. String content = response.body().string();
  132. return content;
  133. } catch (IOException e) {
  134. // TODO Auto-generated catch block
  135. e.printStackTrace();
  136. return null;
  137. }
  138. }
  139. /**
  140. * 日期字符串格式转换
  141. *
  142. * @param dateStr
  143. * @return
  144. */
  145. private String parseStringToDate() {
  146. SimpleDateFormat sdf= new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  147. Date date = new Date();
  148. long dInteger =date.getTime()-65000;
  149. String daString = sdf.format(new Date(dInteger));
  150. return daString;
  151. }
  152. public static void main(String[] args) {
  153. Map<String,String> paramsMap=new HashMap<String,String>();
  154. paramsMap.put("institution_id", "44100001");
  155. String contentString = doPost("https://risserver3.pacsonline.cn/butt/getExam/butt/getExam", paramsMap);
  156. System.out.println(contentString);
  157. }
  158. /**
  159. * 日期字符串格式转换年月日时分秒
  160. *
  161. * @param dateStr
  162. * @return
  163. */
  164. private String parseStringToDateTime() {
  165. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  166. Date date = new Date();
  167. String daString = sdf.format(date);
  168. return daString;
  169. }
  170. /**
  171. * 获取当前时间
  172. * @param dateStr
  173. * @return
  174. */
  175. private String getNowDate() {
  176. SimpleDateFormat sdf= new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  177. Date date = new Date();
  178. //4小时
  179. Date lastDate = new Date(date.getTime()-172800000);
  180. String timeString = null;
  181. timeString = sdf.format(lastDate);
  182. return timeString;
  183. }
  184. }