ViewController.java 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. package com.zskk.control;
  2. import java.io.IOException;
  3. import java.text.ParseException;
  4. import java.text.SimpleDateFormat;
  5. import java.util.Date;
  6. import java.util.HashMap;
  7. import java.util.List;
  8. import java.util.Map;
  9. import com.alibaba.fastjson.JSON;
  10. import com.alibaba.fastjson.JSONArray;
  11. import com.alibaba.fastjson.JSONObject;
  12. import com.jfinal.core.Controller;
  13. import com.jfinal.kit.PropKit;
  14. import com.jfinal.plugin.activerecord.ActiveRecordPlugin;
  15. import com.jfinal.plugin.activerecord.Db;
  16. import com.jfinal.plugin.activerecord.Record;
  17. import com.jfinal.plugin.activerecord.dialect.SqlServerDialect;
  18. import com.jfinal.plugin.druid.DruidPlugin;
  19. import com.zskk.service.DataService;
  20. import com.zskk.service.ServiceFactory;
  21. import com.zskk.service.ThreadPoolService;
  22. import okhttp3.FormBody;
  23. import okhttp3.MediaType;
  24. import okhttp3.OkHttpClient;
  25. import okhttp3.Request;
  26. import okhttp3.RequestBody;
  27. import okhttp3.Response;
  28. public class ViewController extends Controller {
  29. private static final MediaType JSON_CODE = MediaType.get("application/json; charset=utf-8");
  30. private static final OkHttpClient OKHTTP_CLIENT = new OkHttpClient();
  31. /**
  32. * 在被连接数据库执行sql语句
  33. */
  34. public void executeSql() {
  35. List<Record> d = Db.use("connected").find(this.getPara("sqlstr"));
  36. this.renderJson(d);
  37. }
  38. public void testConn() {
  39. try {
  40. DruidPlugin druidPluginConnected = createConnectedDruidPlugin();
  41. druidPluginConnected.start();
  42. // 配置ActiveRecord插件
  43. ActiveRecordPlugin arpConnected = new ActiveRecordPlugin("connected", druidPluginConnected);
  44. arpConnected.setDialect(new SqlServerDialect());
  45. arpConnected.start();
  46. } catch (Exception e) {
  47. // TODO: handle exception
  48. this.renderText(e.toString());
  49. }
  50. }
  51. public void cs() {
  52. try {
  53. DataService dService = ServiceFactory.getService(DataService.class);
  54. JSONArray jsonArray = dService.getExamList(500);
  55. for (Object object : jsonArray) {
  56. JSONObject jsonObject = JSON.parseObject(object.toString());
  57. Record record = Db.use("connected").findFirst("select * from reportinfo where ACCESSIONNUMBER=?", jsonObject.getString("accession_num")==null?jsonObject.getString("patient_num"):jsonObject.getString("accession_num"));
  58. if (record == null) {
  59. continue;
  60. }
  61. if (record.getStr("IMPRESSION") == null && record.getStr("DESCRIPTION") == null) {
  62. continue;
  63. }
  64. Map<String, String> params = new HashMap<>();
  65. params.put("exam_id", jsonObject.getString("id"));
  66. //报告医生姓名
  67. params.put("report_doctor_name", record.getStr("REPORTDOCTOR"));
  68. //报告时间
  69. params.put("report_datetime", parseStringToDate(record.getStr("REPORTDATE")));
  70. //审核医生姓名
  71. params.put("review_doctor_name", record.getStr("REVIEWDOCTOR")==null?"":record.getStr("REVIEWDOCTOR"));
  72. //审核时间
  73. params.put("review_datetime", parseStringToDate(record.getStr("REPORTDATE")));
  74. //确认医生姓名
  75. params.put("confirm_doctor_name", record.getStr("REVIEWDOCTOR")==null?"":record.getStr("REVIEWDOCTOR"));
  76. //确认时间
  77. params.put("confirm_datetime", parseStringToDate(record.getStr("REPORTDATE")));
  78. //意见建议
  79. params.put("impression", record.getStr("IMPRESSION"));
  80. //影像所见
  81. params.put("description", record.getStr("DESCRIPTION"));
  82. //exams表
  83. //申请科室
  84. params.put("application_department", record.getStr("DEPARTMENT")==null?"":record.getStr("DEPARTMENT"));
  85. //申请医生
  86. params.put("application_doctor", record.getStr("CLINICALDOCTOCR")==null?"":record.getStr("CLINICALDOCTOCR"));
  87. //临床诊断
  88. params.put("clin_diag", "");
  89. //症状
  90. params.put("clin_symp", record.getStr("SYMPTOM")==null?"":record.getStr("SYMPTOM"));
  91. //patient_infos表
  92. //患者姓名
  93. params.put("name", record.getStr("PATIENTNAME"));
  94. //患者手机号
  95. params.put("phone", record.getStr("PHONE")==null?"":record.getStr("PHONE"));
  96. //患者身份证号
  97. params.put("card_num", record.getStr("IDCARD")==null?"":record.getStr("IDCARD"));
  98. //检查结果1阴2阳
  99. params.put("report_result", record.getStr("RESULT").contains("阳")?"2":"1");
  100. //门诊号住院号
  101. params.put("hopitalized_no", jsonObject.getString("accession_num")==null?jsonObject.getString("patient_num"):jsonObject.getString("accession_num"));
  102. // ThreadPoolService tService = ServiceFactory.getService(ThreadPoolService.class);
  103. // tService.execute(() -> {
  104. dService.saveReport(params);
  105. // });
  106. }
  107. } catch (Exception e) {
  108. // TODO: handle exception
  109. this.renderText(e.toString());
  110. }
  111. renderNull();
  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. * @param dateStr
  142. * @return
  143. */
  144. private String parseStringToDate(String dateStr) {
  145. if (dateStr == null) {
  146. return "";
  147. }
  148. SimpleDateFormat sdf= new SimpleDateFormat("yyyy.MM.dd HH:mm:ss");
  149. Date date = null;
  150. String timeString = null;
  151. try {
  152. date = sdf.parse(dateStr);
  153. SimpleDateFormat sdf2= new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  154. timeString = sdf2.format(date);
  155. } catch (ParseException e) {
  156. // TODO Auto-generated catch block
  157. e.printStackTrace();
  158. }
  159. return timeString;
  160. }
  161. public static void main(String[] args) {
  162. Map<String,String> paramsMap=new HashMap<String,String>();
  163. paramsMap.put("institution_id", "44100001");
  164. String contentString = doPost("https://risserver3.pacsonline.cn/butt/getExam/butt/getExam", paramsMap);
  165. System.out.println(contentString);
  166. }
  167. }