/** * 根據訂單號,業務標識進行跳轉 * 該方法只作跳轉,不作具體業務處理 */ public function redirectOrder(){ $data = I('get.data'); if(!preg_match('/[A-Za-z0-9]{10}/i',$data)) { //TODO 這裏應該顯示錯誤頁面 $this->response(createResult(403,"非法單號"),'json'); return; } // 截取業務類型 $businessType = substr($data, 0, 1); $order_s = make_bit10(substr("$data",3,7)); // 還原單號 $orderId = substr($data,1,2); if(strlen($order_s) == 12){ $orderId = 'B' . substr($orderId,0,2) . make_bit10(substr("$data",3,7)) . 'd'; }else{ $orderId = 'B' . substr($orderId,0,2) .'0'.make_bit10(substr("$data",3,7)) . 'd'; } $order = M('order'); $map['order_id'] = $orderId; $company_id = $order->where($map)->getField('company_id'); $company = M('company'); $C_map['company_id'] = $company_id; $company_name = $company->where($C_map)->getField('company_name'); // 校驗訂單是否存在 $count = M('order')->where(['order_id' => $orderId])->count(); if (!$count) { //TODO 這裏應該顯示錯誤頁面 $this->response(createResult(404,"訂單不存在"),'json'); return; } // 根據不一樣的業務類型跳轉到不一樣的頁面 switch ($businessType){ case R: header("location: http://fb.cube-y.com/wx/index.php?pages=login&act=login&Idcard=courier&company_name=$company_name&order_id=$orderId"); break; } }
在thinkphp的.htacess文件加上這段,限制訂單號爲10位 #RewriteRule ^[A-Za-z0-9]{10}$ /index.php/RestAPI/Common/redirectOrder/data/$1 [L]
更多php技術交流,可加Q羣:884743303,裏面各路大神爲您保駕護航,php