VM暫存
Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

199 рядки
7.9KB

  1. <?php
  2. /*
  3. file: Payment_ats.php 繳費機
  4. */
  5. if (!defined('BASEPATH')) exit('No direct script access allowed');
  6. class Payment_ats extends CI_Controller
  7. {
  8. var $vars = array(); // 共用變數
  9. function __construct()
  10. {
  11. parent::__construct();
  12. // ----- 程式開發階段log設定 -----
  13. if (@ENVIRONMENT == 'development')
  14. {
  15. ini_set('display_errors', '1');
  16. //error_reporting(E_ALL ^ E_NOTICE);
  17. error_reporting(E_ALL);
  18. }
  19. set_error_handler(array($this, 'error_handler'), E_ALL); // 資料庫異動需做log
  20. // ----- 定義常數(路徑, cache秒數) -----
  21. define('APP_VERSION', '100'); // 版本號
  22. define('MAX_AGE', 604800); // cache秒數, 此定義1個月
  23. define('APP_NAME', 'payment_ats'); // 應用系統名稱
  24. define('PAGE_PATH', APP_BASE.'ci_application/views/'.APP_NAME.'/'); // path of views
  25. define('SERVER_URL', 'http://'.(isset($_SERVER['SERVER_NAME']) ? $_SERVER['SERVER_NAME'] : 'localhost').'/'); // URL
  26. define('APP_URL', SERVER_URL.APP_NAME.'.html/'); // controller路徑
  27. define('WEB_URL', SERVER_URL.APP_NAME.'/'); // 網頁路徑
  28. define('WEB_LIB', SERVER_URL.'libs/'); // 網頁lib
  29. define('BOOTSTRAPS', WEB_LIB.'bootstrap_sb/'); // bootstrap lib
  30. define('LOG_PATH', FILE_BASE.APP_NAME.'/logs/'); // log path
  31. $this->load->model('payment_ats_model'); // 臨停繳費
  32. $this->load->model('allpay_invoice_model'); // 歐付寶電子發票
  33. define('MAIN_PAGE', "main_page");
  34. define('RESULT_PAGE', "result_page");
  35. // ----- 行動支付, 繳費機告知已付款 -----
  36. define('ALTOB_ATS2PAYED', "http://localhost/carpayment.html/ats2payed");
  37. // ----- 行動支付, 繳費機告知已付款 (end) -----
  38. // ----- 歐付寶金流 -----
  39. define('ALLPAY_PAYMENT_TX_BILL_ATS', SERVER_URL."allpay_payment.html/transfer_money_tx_bill_ats"); // 歐付寶付款系統連結
  40. define('ALLPAY_ClientBackURL', APP_URL."client_back/"); // 您要歐付寶返回按鈕導向的瀏覽器端網址";
  41. define('ALLPAY_OrderResultURL', APP_URL."order_result/"); // 您要收到付款完成通知的瀏覽器端網址(browser) ps. WebATM大部份銀行都回不來;
  42. define('ALLPAY_AltobServiceURL', APP_URL."payment_completed_handler/"); // 付款完成後被通知的位址
  43. // ----- 歐付寶金流 (end) -----
  44. }
  45. // 發生錯誤時集中在此處理
  46. public function error_handler($errno, $errstr, $errfile, $errline, $errcontext)
  47. {
  48. $str = date('H:i:s')."|{$errstr}|{$errfile}|{$errline}|{$errno}\n";
  49. //error_log($str, 3, $log_file . '.' . date('Ymd').'.log.txt'); // 3代表參考後面的檔名
  50. error_log($str, 3, LOG_PATH.APP_NAME . '.' . date('Ymd').'.log.txt'); // 3代表參考後面的檔名
  51. }
  52. // 顯示靜態網頁(html檔)
  53. protected function show_page($page_name, $data = null)
  54. {
  55. $page_file = PAGE_PATH.$page_name.'.php';
  56. $last_modified_time = filemtime($page_file);
  57. // 若檔案修改時間沒有異動, 或版本無異動, 通知瀏覽器使用cache, 不再下傳網頁
  58. // header('Cache-Control:max-age='.MAX_AGE); // cache 1個月
  59. header('Last-Modified: '.gmdate('D, d M Y H:i:s', $last_modified_time).' GMT');
  60. header('Etag: '. APP_VERSION);
  61. header('Cache-Control: public');
  62. if (!empty($_SERVER['HTTP_IF_NONE_MATCH']) && $_SERVER['HTTP_IF_NONE_MATCH'] == APP_VERSION && @strtotime($_SERVER['HTTP_IF_MODIFIED_SINCE']) == $last_modified_time)
  63. {
  64. header('HTTP/1.1 304 Not Modified');
  65. }
  66. else
  67. {
  68. $this->load->view(APP_NAME.'/'.$page_name, $data);
  69. }
  70. }
  71. // 首頁
  72. public function index()
  73. {
  74. $this->show_page(MAIN_PAGE);
  75. }
  76. // 查車付款 - 1.查車拿帳單
  77. public function payment_lpr()
  78. {
  79. $payment_lpr = $this->input->post('payment_lpr', true);
  80. $data = $this->payment_ats_model->create_member_bill($payment_lpr);
  81. echo json_encode($data, JSON_UNESCAPED_UNICODE);
  82. }
  83. // 查車付款 - 2.確定繳交帳單
  84. public function transfer_money()
  85. {
  86. $order_no = strtoupper($this->uri->segment(3)); // 交易序號
  87. $invoice_receiver = urldecode($this->uri->segment(4)); // 載具編號 (可有可無)
  88. $company_no = urldecode($this->uri->segment(5)); // 公司統編 (可有可無)
  89. $email_base64 = $this->uri->segment(6); // 電子信箱
  90. $mobile = $this->uri->segment(7); // 手機號碼
  91. // decode email
  92. if(strlen($email_base64) > 0){
  93. $email = base64_decode($email_base64.'='); // base64字串尾端的'='還原
  94. }else{
  95. $email = email_base64;
  96. }
  97. $this->payment_ats_model-> // 開始進行繳交帳單
  98. pay_bill($order_no, $invoice_receiver, $company_no, $email, $mobile,
  99. ALLPAY_ClientBackURL,
  100. ALLPAY_OrderResultURL,
  101. ALLPAY_AltobServiceURL,
  102. 50); // 交易種類: 0:未定義, 1:現金, 40:博辰人工模組, 41:博辰自動繳費機, 50:歐付寶轉址刷卡, 51:歐付寶APP, 52:歐付寶轉址WebATM, 60:中國信託刷卡轉址
  103. // 轉址歐付寶付款系統
  104. echo file_get_contents(ALLPAY_PAYMENT_TX_BILL_ATS."/{$order_no}");
  105. }
  106. // L.1 付款完成 (限制存取)
  107. public function payment_completed_handler()
  108. {
  109. $order_no = $this->uri->segment(3); // 交易序號
  110. $data = $this->payment_ats_model->get_tx_bill($order_no);
  111. if (! empty($data))
  112. {
  113. $order_no = $data['order_no'];
  114. $station_no = $data['station_no'];
  115. $lpr = $data['lpr'];
  116. $amt = $data['amt'];
  117. $status = $data['status'];
  118. switch($status){
  119. case 1: // 狀態: 0:剛建立, 1:結帳完成, 2:錢沒對上, 3:發票沒建立, 4:手動調整, 99:訂單逾期作廢, 100:交易進行中, 111:產品已領取
  120. // 開立歐付寶電子發票
  121. $this->allpay_invoice_model->invoice_issue_for_tx_bill_ats($order_no, $amt);
  122. // 記錄為已領取
  123. $this->payment_ats_model->transfer_money_done_and_finished($order_no);
  124. // 繳費機告知已付款
  125. // http://localhost/carpayment.html/ats2payed/車牌/金額/場站編號/序號/MD5
  126. // md5(車牌.金額.場站編號.序號)
  127. $md5 = md5($lpr.$amt.$station_no.$order_no);
  128. file_get_contents(ALTOB_ATS2PAYED."/{$lpr}/{$amt}/{$station_no}/{$order_no}/{$md5}");
  129. default:
  130. // 尚未結帳完成, 或是已領取
  131. trigger_error(APP_NAME.', '.__FUNCTION__.', order_no=>' . $order_no.'<br>'.' status != 1');
  132. }
  133. }
  134. }
  135. // 歐付寶返回按鈕導向的瀏覽器端網址
  136. public function client_back()
  137. {
  138. $this->show_page(MAIN_PAGE);
  139. }
  140. // 收到付款完成通知的瀏覽器端網址(browser) ps. WebATM大部份銀行都回不來
  141. public function order_result()
  142. {
  143. $this->show_page(RESULT_PAGE);
  144. }
  145. // 其它功能 1: 更改會員密碼
  146. public function change_pswd()
  147. {
  148. $lpr = $this->input->post('lpr', true);
  149. $new_pswd = $this->input->post('new_pswd', true);
  150. $data = $this->security_model->change_pswd($lpr, $new_pswd);
  151. echo json_encode($data, JSON_UNESCAPED_UNICODE);
  152. }
  153. // 其它功能 2: 防盜鎖車
  154. public function security_action()
  155. {
  156. $lpr = $this->uri->segment(3);
  157. $pswd = $this->uri->segment(4);
  158. $action = $this->uri->segment(5);
  159. $data = $this->security_model->security_action($lpr, $pswd, $action);
  160. echo json_encode($data, JSON_UNESCAPED_UNICODE);
  161. }
  162. }