Aatest.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465
  1. <?php defined('BASEPATH') OR exit('No direct script access allowed');
  2. class Aatest extends Start_Controller {
  3. public function __construct(){
  4. parent::__construct();
  5. $this->load->library('session');
  6. $this->load->_model('Model_whlabel','whlabel');
  7. $this->load->_model('Model_warehouse','warehouse');
  8. $this->load->_model('Model_productprice','productprice');
  9. $this->load->_model('Model_excel','excel');
  10. $this->load->_model('Model_fullorder','fullorder');
  11. $this->load->_model('Model_fullordertt','fullordertt');
  12. $this->load->_model('Model_fullordersmt','fullordersmt');
  13. $this->load->_model('Model_outbound','outbound');
  14. $this->load->_model('Model_express','express');
  15. $this->load->_model('Model_shop','shop');
  16. $this->load->_model('Model_typeclass','typeclass');
  17. $this->load->_model('Model_country','country');
  18. $this->load->_model('Model_kdniao','kdniao');
  19. $this->load->_model('Model_notice','notice');
  20. $this->load->_model('Model_dhl','dhl');
  21. $this->load->_model('Model_dhlhz','dhlhz');
  22. $this->load->_model('Model_usps','usps');
  23. $this->load->_model('Model_fedex','fedex');
  24. $this->load->_model('Model_fedex_cby','fedex_cby');
  25. $this->load->_model('Model_ups','ups');
  26. $this->load->_model('Model_ali','ali');
  27. $this->load->_model('Model_dpd','dpd');
  28. $this->load->_model('Model_shop','shop');
  29. $this->load->_model('Model_user','user');
  30. $this->load->_model('Model_whlabel','whlabel');
  31. $this->load->_model('Model_specialstock','specialstock');
  32. $this->load->_model('Model_ck','ck');
  33. $this->load->_model('Model_whlabellabel','whlabellabel');
  34. $this->load->_model('Model_apiyy','apiyy');
  35. $this->load->helper('url');
  36. $this->load->_model('Model_whlabel_fc','whlabel_fc');
  37. $this->load->_model('Model_systemtransfer','systemtransfer');
  38. $this->load->_model('Model_classid','classid');
  39. $this->load->_model('Model_allocation','allocation');
  40. $this->load->_model('Model_fullorderxw','fullorderxw');
  41. $this->load->_model('Model_fullorderpaypal','fullorderpaypal');
  42. $this->load->_model('Model_fedexv1','fedexv1');
  43. $this->load->_model('Model_logic_crm','logic_crm');
  44. $this->load->_model("Model_fullorder","fullorder");
  45. $this->load->_model("Model_express","express");
  46. $this->load->_model("Model_logic_ding","logic_ding");
  47. $this->load->_model("Model_api",'api');
  48. $this->load->_model("Model_usps",'usps');
  49. $this->load->_model('Model_emaildata','emaildata');
  50. $this->load->_model('Model_logic_tools','logic_tools');
  51. $this->load->_model('Model_logic_order','logic_order');
  52. $this->load->_model('Model_returngoods','returngoods');
  53. $this->load->_model('Model_returnlogs','returnlogs');
  54. $this->load->_model('Model_productdescribe','productdescribe');
  55. $this->load->_model('Model_logic_u9tools','logic_u9tools');
  56. }
  57. //定义方法的调用规则 获取URI第二段值
  58. public function _remap($arg,$arg_array)
  59. {
  60. if($arg == 'fout')
  61. {
  62. $this->_fout();
  63. }else if($arg == 'waybillemail'){
  64. $this->_waybillemail();
  65. }else if($arg == 'getorder'){
  66. $this->_getorder();
  67. }elseif($arg == 'logistic'){
  68. $this->_logistic();
  69. }elseif($arg == 'th'){
  70. $this->_th($arg_array);
  71. }else{
  72. $this->_a($arg_array);
  73. }
  74. }
  75. public function _th($arg_array){
  76. die;
  77. if(empty($arg_array)){
  78. die(1);
  79. }
  80. $order_no = $arg_array[0];
  81. var_dump($order_no);
  82. $data = $this->fullorder->get_number($order_no);
  83. if(empty($data)){
  84. echo 2;
  85. exit(2);
  86. }
  87. $r = $this->usps->get_return($data);
  88. echo "<pre>";
  89. var_dump($r);
  90. }
  91. //物流轨迹
  92. public function _logistic(){
  93. echo "<pre>";
  94. // $list = $this->fullorder->find_all("waybill = 284280923614");
  95. // var_dump($list);
  96. // die;
  97. // $v = $list[0];
  98. // $v = [
  99. // 'waybill'=>'285250961332'
  100. // ];
  101. // $fs = $this->fedexv1->get_logistics($v);
  102. // var_dump($fs);
  103. // die;
  104. die;
  105. $list = $this->fullorder->get_waybill("9205890251001335261703");
  106. $v = $list;
  107. @$fs = $this->usps->get_logistics_new($v);
  108. // $csck[] = array($v['number'],$fs['f'],$fs['content']);
  109. // if(!isset($fs['f']))
  110. // {
  111. // $fs = $this->usps->get_logistics($v);
  112. // }
  113. var_dump($fs);
  114. //$fs = $this->usps->get_logistics($v);
  115. die;
  116. }
  117. public function _getorder(){
  118. $name = 'SuperNova';
  119. $userKey = array(
  120. 'Alipearl' => array('username'=>'huchunmei','api_key'=>'huchunmei126_alipearl_erp888','url'=>'https://www.alipearlhair.com'),
  121. 'Asteria' => array('username'=>'huchunmei','api_key'=>'huchunmei126_asteria_erp888','url'=>'https://www.asteriahair.com'),
  122. 'WestKiss' => array('username'=>'huchunmei','api_key'=>'huchunmei126_westkiss_erp868','url'=>'https://www.westkiss.com'),
  123. 'SuperNova' => array('username'=>'huchunmei','api_key'=>'huchunmei126_supernova_erp6898','url'=>'https://www.supernovahair.com'),
  124. 'Wiggins' => array('username'=>'huchunmei','api_key'=>'huchunmei126_wiggins_erp652','url'=>'https://www.wigginshair.com'),
  125. 'Yolissa' => array('username'=>'huchunmei','api_key'=>'huchunmei126_yolissa_688','url'=>'https://www.yolissahair.com'),
  126. );
  127. $proxy = new SoapClient($userKey[$name]['url'].'/api/soap/?wsdl');
  128. try {
  129. $sessionId = $proxy->login($userKey[$name]['username'], $userKey[$name]['api_key']);
  130. }
  131. catch (Exception $e) {
  132. echo $e->getMessage();
  133. }
  134. $data = array('proxy'=>$proxy,'sessionId'=>$sessionId,'url'=>$userKey[$name]['url']);
  135. $fromTime = date('Y-m-d H:i:s',time()- 3600*24*6);
  136. $toTime = date('Y-m-d H:i:s',time());
  137. $filters = array(array('created_at'=>array('from'=>$fromTime,'to'=>$toTime)));
  138. $result = $data['proxy']->call($data['sessionId'],'sales_order.list',$filters);
  139. echo "<pre>";
  140. // print_r($result[0]);
  141. foreach($result as $item)
  142. {
  143. // print_r($item);exit;
  144. $iteminfo= $data['proxy']->call($data['sessionId'], 'sales_order.info', $item['increment_id']);
  145. print_r($iteminfo['items']);
  146. die;
  147. }
  148. }
  149. public function getDtc(){
  150. $dictionaries = $this->typeclass->find_all('spare!= "" and classid != 1 and classid != 2 and classid != 3 and classid != 4 and classid != 5 and classid != 11 and classid != 16 and classid != 17 and classid != 20 and classid != 21 and classid != 23 and classid != 24 and classid != 29 and classid != 30 and classid != 31 and classid != 32 and classid != 36');
  151. $dtc = array();
  152. foreach ($dictionaries as $v)
  153. {
  154. if(stripos($v['spare'],'|') !== false)//如果有多个值
  155. {
  156. $v['spare'] = explode('|',$v['spare']);
  157. foreach ($v['spare'] as $k=>$vs)
  158. {
  159. if(stripos($v['zh'],'|') !== false)
  160. {
  161. $vzh = explode('|',$v['zh']);
  162. $dtc[strtolower($vs)] = array('classid'=>$v['classid'],'zh'=>$vzh[$k],'id'=>$v['id'],'jm'=>$v['jm'],'spare'=>$vs);
  163. }
  164. else
  165. {
  166. $dtc[strtolower($vs)] = array('classid'=>$v['classid'],'zh'=>$v['zh'],'id'=>$v['id'],'jm'=>$v['jm'],'spare'=>$vs);
  167. }
  168. }
  169. }
  170. else
  171. {
  172. $dtc[strtolower($v['spare'])] = array('classid'=>$v['classid'],'zh'=>$v['zh'],'id'=>$v['id'],'jm'=>$v['jm'],'spare'=>$v['spare']);
  173. }
  174. }
  175. $dtctitle = [];
  176. $dictionaries2 = $this->typeclass->find_all();
  177. foreach ($dictionaries2 as $v)
  178. {
  179. $dtctitle[$v['id']] = $v['title'];
  180. }
  181. return [
  182. 'dtc'=>$dtc,
  183. 'dtctitle'=>$dtctitle
  184. ];
  185. }
  186. public function _a($arg_array){
  187. $list = [
  188. [
  189. 'sku2'=>'-128-80-89-57-106-341-30-72-',
  190. ],
  191. [
  192. 'sku2'=>'-128-80-88-57-2248-2096-30-72-2071-1645-',
  193. ]
  194. ];
  195. $r = $this->logic_u9tools->getU9bm($list,'sku2');
  196. echo "<pre>";
  197. var_dump($r);
  198. die;
  199. $data = $this->getDtc();
  200. $dtc = $data['dtc'];
  201. $dtctitle = $data['dtctitle'];
  202. $quantity = 'Loose Body--HDWig-26-HD5*5Wig-180%,WKPack';
  203. $issku = '1;1';
  204. $money = array();
  205. $productdescribe = $this->productdescribe->find_all('1=1');
  206. foreach ($productdescribe as $v)
  207. {
  208. $money[$v['number']] = array();
  209. }
  210. /* 价格加入 */
  211. /* 匹配ID加入 */
  212. $int = array();
  213. $intdata = $this->typeclass->find_all('classid=14','id,spare');
  214. foreach ($intdata as $v)
  215. {
  216. $v['spare'] = explode('|',$v['spare']);
  217. $int[$v['id']] = $v['spare'][0];
  218. }
  219. var_dump($dtc);
  220. var_dump($dtctitle);
  221. $r = $this->api->matching($quantity,$issku,$dtc,$money,$int,$dtctitle,[1],[
  222. ]);
  223. echo "<pre>";
  224. var_dump($r);
  225. die;
  226. $time = time();
  227. $jiami = "alipearlhair+".(string)$time;
  228. echo json_encode([
  229. 'shop'=>3,
  230. 'waybill'=>'283786008019',
  231. 'time'=>$time,
  232. 'key'=>$this->logic_tools->toolsjiami($jiami,"6amg!pnfrlbpnjgirv", "6ook4k!2w94m6jtm"),
  233. ]);
  234. die;
  235. $dtc = array();
  236. /* 订单号加入键值-j */
  237. /* 匹配加入 */
  238. $dictionaries = $this->typeclass->find_all('spare!= "" and classid != 1 and classid != 2 and classid != 3 and classid != 4 and classid != 5 and classid != 11 and classid != 16 and classid != 17 and classid != 20 and classid != 21 and classid != 23 and classid != 24 and classid != 29 and classid != 30 and classid != 31 and classid != 32 and classid != 36');
  239. // and (classid=13 or classid=22 or classid=8 or classid=15 or classid=27 or classid=25 or classid=26 or classid=18 or classid=14 or classid=9 or classid=12 or classid=10 or classid=6 or classid=100 or classid=999)
  240. foreach ($dictionaries as $v)
  241. {
  242. if(stripos($v['spare'],'|') !== false)//如果有多个值
  243. {
  244. $v['spare'] = explode('|',$v['spare']);
  245. foreach ($v['spare'] as $k=>$vs)
  246. {
  247. if(stripos($v['zh'],'|') !== false)
  248. {
  249. $vzh = explode('|',$v['zh']);
  250. $dtc[strtolower($vs)] = array('classid'=>$v['classid'],'zh'=>$vzh[$k],'id'=>$v['id'],'jm'=>$v['jm'],'spare'=>$vs);
  251. }
  252. else
  253. {
  254. $dtc[strtolower($vs)] = array('classid'=>$v['classid'],'zh'=>$v['zh'],'id'=>$v['id'],'jm'=>$v['jm'],'spare'=>$vs);
  255. }
  256. }
  257. }
  258. else
  259. {
  260. $dtc[strtolower($v['spare'])] = array('classid'=>$v['classid'],'zh'=>$v['zh'],'id'=>$v['id'],'jm'=>$v['jm'],'spare'=>$v['spare']);
  261. }
  262. }
  263. $dtctitle = [];
  264. $dictionaries2 = $this->typeclass->find_all();
  265. foreach ($dictionaries2 as $v)
  266. {
  267. $dtctitle[$v['id']] = $v['title'];
  268. }
  269. echo "<pre>";
  270. $sku = "Free,Gift--PackQQS,NW--3+Ori6*6C-22 24 26-20-6*6C";
  271. $sl = "1;1;1;";
  272. $r = $this->api->matching($sl,$sku,$dtc,"","",$dtctitle,$shop=[],$extra = [
  273. "price"=>"565.7700",
  274. "row_total"=>"565.7700"
  275. ]);
  276. var_dump($r['title']);
  277. $r = $r['product'];
  278. $rr = explode(";",$r);
  279. print_r($rr);
  280. }
  281. public function _fout()
  282. {
  283. $waybill = $this->input->get('waybill');
  284. $info = $this->fullorder->get_waybill($waybill);
  285. //$r = $this->usps->get_new_logistics($info);
  286. $r = $this->fedexv1->get_logistics(123);
  287. echo "<pre>";
  288. var_dump($r);
  289. //$this->fedexv1->makeAccessToken();
  290. }
  291. public function _waybillemail()
  292. {
  293. $urls = array();$sl = 0;$time = time();
  294. $wid = 2;
  295. // if(date("H",time()) == '8' && date("i",time()) > '20' && date("i",time()) < '39')//USPS-USA单
  296. // {
  297. // $wid = 1;
  298. // }
  299. // else if(date("H",time()) == '20' && date("i",time()) > '20' && date("i",time()) < '39')//其他快递
  300. // {
  301. // $wid = 2;
  302. // }
  303. // else
  304. // {
  305. // exit;
  306. // }
  307. $notice = $this->notice->find_all("message = '1' and state = '1' and type = '4' and ktime < '$time' and jtime > '$time'");//已有自动发送,这个是物流发送
  308. foreach ($notice as $key=>$var)
  309. {
  310. $this->_waybillfs([
  311. 'var'=>$var,
  312. 'wid'=>$wid
  313. ]);
  314. }
  315. }
  316. public function upadtel(){
  317. $returngoods_id = 150;
  318. $insert_flag = 1217819;
  319. $number = 'KISS-50206-004';
  320. $returngoods_info = $this->returngoods->read($returngoods_id);
  321. $this->returngoods->save([
  322. 'status'=>80,
  323. 'back_no'=>$number,
  324. 'back_id'=>$insert_flag,
  325. 'update_time'=>date('Y-m-d H:i:s'),
  326. ],$returngoods_id);
  327. $this->returnlogs->insert([
  328. 'rg_id'=>(int)$returngoods_id,
  329. 'operat_id'=>10,
  330. 'operat_name'=>'admin',
  331. 'remark'=>"订单号:".$returngoods_info['orderinfo']."重新换货-换货新订单编码".$number,
  332. 'create_time'=>date('Y-m-d H:i:s'),
  333. ]);
  334. }
  335. public function _waybillfs($data)
  336. {
  337. if($data)
  338. {
  339. $notice = $data['var'];
  340. $notice['email'] = $this->emaildata->read($notice['email']);
  341. $wid = $data['wid'];
  342. $fsjs = "";
  343. if($wid == 1 && (stripos($notice['express'],',2,') !== false || stripos($notice['express'],',63,') !== false || stripos($notice['express'],',64,') !== false))
  344. {
  345. $js = explode(',',trim($notice['js'],','));
  346. if(count($js) > 1)
  347. {
  348. $fsjs = " and (";
  349. foreach ($js as $v)
  350. {
  351. $fsjs .= "js = '$v' or ";
  352. }
  353. $fsjs = trim($fsjs,' or ').")" ;
  354. }
  355. else if(count($js) == 1)
  356. {
  357. $fsjs = " and js = '$js[0]'";
  358. }
  359. $where = "(express = '2' or express = '63' or express = '64') and librarytime > '".strtotime(date("Y-m-d 8:30:0",strtotime("-6 day")))."' and librarytime < '".strtotime(date("Y-m-d 8:30:0",time()))."'".$fsjs;//3
  360. }
  361. else if($wid == 2 && stripos($notice['express'],',1,') !== false)
  362. {
  363. $where = "express != '2' and express != '63' and express != '64' and printtype = '1' and waybill != '' and librarytime > '".strtotime(date("Y-m-d 20:00:0",strtotime("-6 day")))."' and librarytime < '".strtotime(date("Y-m-d 20:00:0",time()))."'";//4
  364. }
  365. else
  366. {
  367. exit;
  368. }
  369. $this->logic_ding->sendToDing("source != '1' and dlzemail < '1' and shop = '".$notice['shop']."' and library = 2 and ".$where);
  370. // $wlfs = array();
  371. // $dd = $this->fullorder->find_all("source != '1' and dlzemail < '1' and shop = '".$notice['shop']."' and library = 2 and ".$where);
  372. // foreach($dd as $v){
  373. // $this->logic_ding->sendToDing($v['orderinfo']."监听邮件发送的异常:订单信息【".json_encode($v,JSON_UNESCAPED_UNICODE)."】");
  374. // }
  375. // foreach ($dd as $v)
  376. // {
  377. // $shop = $this->shop->read($v['shop']);
  378. // $express = $this->express->read($v['express']);
  379. // $fs = $this->notice->get_god($v,$shop,$express,$notice);
  380. // $this->logic_ding->sendToDing($v['orderinfo']."监听邮件发送的异常:订单信息【".json_encode($v,JSON_UNESCAPED_UNICODE)."】获取快递信息【".json_encode($notice,JSON_UNESCAPED_UNICODE)."】返回的信息".json_encode($fs));
  381. // if($fs == 1)
  382. // {
  383. // $this->fullorder->save(array('dlzemail'=>1,'dlzemailtime'=>time()),$v['id']);
  384. // //给crm发送信息 先存储数据 后续定时任务执行
  385. // if($v['shop'] < 10){
  386. // $this->zztmpdata->insert([
  387. // 'type'=>2,
  388. // 'act_name'=>'crm_order',
  389. // 'content'=>json_encode($v),
  390. // 'create_time'=>time()
  391. // ]);
  392. // }
  393. // }
  394. // else
  395. // {
  396. // //$pdtime = date('Y-m-d',time());
  397. // //$folderPath = './data/dlzemail/'.$pdtime; // 文件夹路径
  398. // //$permissions = 0777; // 权限设置
  399. // //if (!file_exists($folderPath)) { mkdir($folderPath, $permissions); }//创建文件夹
  400. // //file_exists($folderPath);
  401. // if(!is_file("./data/dlzemail/".$v['number'].".txt"))
  402. // {
  403. // $myfile = fopen("./data/dlzemail/".$v['number'].".txt", "w") or die("Unable to open file!");
  404. // fwrite($myfile, json_encode($fs.';'.$v.';'.$shop.';'.$express.';'.$notice));
  405. // fclose($myfile);
  406. // }
  407. // else
  408. // {
  409. // $myfile = fopen("./data/dlzemail/".$v['number'].".txt", "a+") or die("Unable to open file!");
  410. // fwrite($myfile, json_encode($fs.';'.$v.';'.$shop.';'.$express.';'.$notice));
  411. // fclose($myfile);
  412. // }
  413. // $this->fullorder->save(array('dlzemail'=>2,'dlzemailtime'=>time()),$v['id']);
  414. // }
  415. // sleep(50);
  416. // }
  417. }
  418. }
  419. }