Index.php 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. <?php
  2. namespace app\controller;
  3. use app\BaseController;
  4. use app\common\array2xml;
  5. use think\facade\Config;
  6. use think\facade\Db;
  7. use think\facade\Cache;
  8. class Index extends BaseController
  9. {
  10. public function index()
  11. {
  12. $this->getPdf('12206060840002');
  13. // phpinfo();
  14. }
  15. public function hello($name = 'ThinkPHP6')
  16. {
  17. return 'hello,' . $name;
  18. }
  19. public function getReport()
  20. {
  21. $code = $_REQUEST['code'];
  22. $type = $_REQUEST['type'];
  23. libxml_disable_entity_loader(false);
  24. // $client = new \SoapClient("http://report.dalabs.cn/RasClientDetail.asmx?wsdl");
  25. $client = new \SoapClient("http://115.238.253.166/RasClientDetail.asmx?wsdl");
  26. $data = [
  27. 'ClientID'=>Config::get('app')['dian']['ClientID'],
  28. 'ClientGUID'=>Config::get('app')['dian']['ClientGUID'],
  29. 'hospBarcode'=>$code,
  30. 'SelectType'=>$type
  31. ]; //请求参数
  32. Db::table('api_log')->insert(['type'=>1,'barcode'=>$code]);
  33. try{
  34. $result = $client->GetDetailDataByHospBarcode3($data); //请求获取接口
  35. Db::table('api_log')->insert(['type'=>2,'barcode'=>$code]);
  36. $data = ((array)$result)['GetDetailDataByHospBarcode3Result'];
  37. $obj = simplexml_load_string("<data>".$data."</data>","SimpleXMLElement", LIBXML_NOCDATA);
  38. if($obj)
  39. {
  40. $info = json_decode(json_encode($obj),true);
  41. $returnCode = $info['Error']['Code'];
  42. if($returnCode !== '0')
  43. {
  44. return '报告获取失败!迪安回传信息:'.$info['Error']['Descript'];
  45. }
  46. }
  47. $report = json_encode($obj);
  48. DB::table('dianapiinfo')->where('Barcode',$code)->update(['result_xml'=>$report]);
  49. $this->getPdf($code);
  50. return 'success';
  51. }catch(\SoapFault $e){
  52. return $e->getMessage();
  53. }
  54. }
  55. public function getPdf($code)
  56. {
  57. $type = 1;
  58. libxml_disable_entity_loader(false);
  59. $client = new \SoapClient("https://r.dalabs.cn/ReportService.asmx?wsdl");
  60. $data = ['ReqInfo'=>[
  61. 'ClientID'=>Config::get('app')['dian']['ClientID'],
  62. 'Key'=>Config::get('app')['dian']['ClientGUID'],
  63. 'PageNO'=>1,
  64. 'CONDITION'=>[
  65. 'ClinicID'=>$code,
  66. 'StartDate'=>'',
  67. 'EndDate'=>''
  68. ],
  69. 'Model'=>1
  70. ]
  71. ]; //请求参数
  72. // try{
  73. $a2x = new array2xml();
  74. $data = $a2x->toXml($data);
  75. $data = "<s:Envelope xmlns:s=\"http://schemas.xmlsoap.org/soap/envelope/\"><s:Body><QueryReports2 xmlns=\"http://r.dalabs.cn\" xmlns:i=\"http://www.w3.org/2001/XMLSchema-instance\"><ReqInfo><ClientID>黑龙江昆仑上德体检中心</ClientID><Key>79A5CFF272A203F9E0530BF0000AE4D1</Key><PageNo>1</PageNo><Condition><ClinicID>12206060840019</ClinicID><StartDate/><EndDate/></Condition></ReqInfo></QueryReports2></s:Body></s:Envelope>";
  76. // var_dump(htmlspecialchars($data));
  77. // var_dump($data);
  78. $result = $client->QueryReports2(array('ReqInfo'=>$data)); //请求获取接口
  79. var_dump($result);die;
  80. Db::table('dianapiinfo')->where('Barcode',$code)->update(['pdf_xml'=>$result]);
  81. $data = ((array)$result)['GetReportInfoResult'];
  82. $obj = simplexml_load_string("<data>".$data."</data>","SimpleXMLElement", LIBXML_NOCDATA);
  83. Db::table('api_log')->insert(['type'=>4,'barcode'=>$code]);
  84. if($obj)
  85. {
  86. $info = json_decode(json_encode($obj),true);
  87. $returnCode = $info['Msg']['Code'];
  88. if($returnCode !== '1')
  89. {
  90. return '报告PDF获取失败!迪安回传信息:'.$info['Msg']['Descript'];
  91. }
  92. if(isset($info['NewDataSet']['Table1']['BARCODE']))
  93. {
  94. $pdf = $info['NewDataSet']['Table1']['PDFREPORTURL'];
  95. $name = $info['NewDataSet']['Table1']['BARCODE'];
  96. $this->downImgRar($pdf,$name,'pdf',$info['NewDataSet']['Table1']['BARCODE']);
  97. }else{
  98. foreach ($info['NewDataSet']['Table1'] as $k=>$v)
  99. {
  100. $pdf = $v['PDFREPORTURL'];
  101. $name = $v['BARCODE'].'_'.($k+1);
  102. $this->downImgRar($pdf,$name,'pdf',$v['BARCODE']);
  103. }
  104. }
  105. }
  106. return 'success';
  107. // }catch(\SoapFault $e){
  108. // return $e->getMessage();
  109. // }
  110. }
  111. function downImgRar($url,$rename,$ext,$barCode){
  112. switch ($ext) {
  113. case 'png':
  114. case 'jpg': //下载图片
  115. $file_path = '/images/';
  116. break;
  117. case 'pdf': //下载PDF
  118. $file_path = '/pdf/';
  119. break;
  120. case 'zip':
  121. case 'rar': //下载压缩包
  122. $file_path = '/rar/';
  123. break;
  124. default:
  125. $file_path = '/files/';
  126. break;
  127. }
  128. $ch = curl_init($url);
  129. curl_setopt($ch, CURLOPT_HEADER, 0);
  130. curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
  131. curl_setopt($ch, CURLOPT_BINARYTRANSFER,1);
  132. $rawdata=curl_exec ($ch);
  133. curl_close ($ch);
  134. // 使用中文文件名需要转码
  135. file_put_contents($_SERVER['DOCUMENT_ROOT'].$file_path.$rename.'.'.$ext,$rawdata);
  136. // 返回路径
  137. $path = $_SERVER['DOCUMENT_ROOT'].$file_path.$rename.".".$ext;
  138. $ins = ['type'=>$ext,'url'=>$path,'barcode'=>$barCode];
  139. Db::table('annex')->insert($ins);
  140. $patientId = Db::table('dianapiinfo')->where('Barcode',$barCode)->value('patientId');
  141. Db::table('phy_lis_reports')->where('patientId',$patientId)->update(['is_report_url'=>1]);
  142. return 'success';
  143. }
  144. }