join('ims_cjdc_order as o','o.order_main_id', '=', 'm.id','inner') ->join('ims_cjdc_order_goods as g','o.id','=', 'g.order_id','inner') ->join('ims_cjdc_feprint as f','m.market_id','=', 'f.market_id','inner') ->join('ims_cjdc_store as s','s.id','=', 'o.store_id','inner') ->where('m.global_order_id', $order_num) ->selectRaw("o.note as o_note,g.name,g.number,g.money,g.good_unit,m.delivery_time as ps_time,m.address,m.note,m.name as user_name,m.dada_fee,m.money as m_money,m.yhq_money2,m.box_money,f.sn,m.tel,m.order_num,g.id,g.spec,s.name as shopname") ->orderBy('s.id') ->get() ->toArray(); foreach ($data as $key => &$item) { $item = (array)$item; } $content = $this->printFormat($data, 14, 6, 3, 6); $res = $this->printMsg($data[0]['sn'], $content, 1); return ($res); } /** * [打印订单接口 Open_printMsg] * @param [string] $sn [打印机编号sn] * @param [string] $content [打印内容] * @param [string] $times [打印联数] * @return [string] [接口返回值] */ protected function printMsg($sn, $content, $times = 1) { $time = time(); //请求时间 $msgInfo = array( 'user' => self::USER, 'stime' => $time, 'sig' => sha1(self::USER . self::UKEY . $time), 'apiname' => 'Open_printMsg', 'sn' => $sn, 'content' => $content, 'times' => $times//打印次数 ); $client = new FeiePrintClient(self::IP, self::PORT); if (!$client->post(self::PATH, $msgInfo)) { echo 'error'; } else { // 服务器返回的JSON字符串,建议要当做日志记录起来 $result = $client->getContent(); return $result; } } protected function printFormat($arr, $A, $B, $C, $D) { $orderInfo = '懒族生活
'; $orderInfo .= '名称 单价 数量 金额
'; $orderInfo .= '--------------------------------
'; $shopname = ""; $shopnum = 0; foreach ($arr as $k5 => $v5) { if ($shopname != $v5['shopname']) { if ($shopname != "") { $orderInfo .= '
'; } $shopnum++; $orderInfo .= "(" . $shopnum . ")" .$v5['shopname'] . '
'; $shopname = $v5['shopname']; } $name = $v5['name']; if(!empty($v5['spec'])) { $name .= "(规格:". $v5['spec'].")"; }elseif (!empty($v5['good_unit'])){ $name .= "(规格:". $v5['good_unit'].")"; } $price = $v5['money']; $num = $v5['number']; $prices = sprintf("%.2f",$v5['money']*$v5['number']); $kw3 = ''; $kw1 = ''; $kw2 = ''; $kw4 = ''; $str = $name; $blankNum = $A;//名称控制为14个字节 $lan = mb_strlen($str,'utf-8'); $m = 0; $j=1; $blankNum++; $result = array(); if(strlen($price) < $B){ $k1 = $B - strlen($price); for($q=0;$q<$k1;$q++){ $kw1 .= ' '; } $price = $kw1.$price; } if(strlen($num) < $C){ $k2 = $C - strlen($num); for($q=0;$q<$k2;$q++){ $kw2 .= ' '; } $num = $kw2.$num; } if(strlen($prices) < $D){ $k3 = $D - strlen($prices); for($q=0;$q<$k3;$q++){ $kw4 .= ' '; } $prices = $kw4.$prices; } for ($i=0;$i<$lan;$i++){ $new = mb_substr($str,$m,$j,'utf-8'); $j++; if(mb_strwidth($new,'utf-8')<$blankNum) { if($m+$j>$lan) { $m = $m+$j; $tail = $new; // $lenght = iconv("UTF-8", "GBK//IGNORE", $new); $k = $A - mb_strwidth($new,'utf-8'); for($q=0;$q<$k;$q++){ $kw3 .= ' '; } if($m==$j){ $tail .= $kw3.' '.$price.' '.$num.' '.$prices; }else{ $tail .= $kw3.'
'; } break; }else{ $next_new = mb_substr($str,$m,$j,'utf-8'); if(mb_strwidth($next_new,'utf-8')<$blankNum) continue; else{ $m = $i+1; $result[] = $new; $j=1; } } } } $head = ''; foreach ($result as $key=>$value) { if($key < 1){ // $v_lenght = iconv("UTF-8", "GBK//IGNORE", $value); $v_lenght = mb_strwidth($value,'utf-8'); if($v_lenght == 13) $value = $value." "; $head .= $value.' '.$price.' '.$num.' '.$prices; }else{ $head .= $value.'
'; } } $orderInfo .= $head.$tail; if(!empty($v5['o_note'])){ $orderInfo .= '备注:'.$v5['o_note'].'
'; } } // $time = date('Y-m-d H:i:s', time()); $orderInfo .= '--------------------------------
'; if ($arr[0]['box_money'] > 0) { $kw5 = ''; $len = 24 - strlen($arr[0]['box_money']); for ($q = 0; $q < $len; $q++) { $kw5 .= ' '; } $orderInfo .= '包装费:' . $kw5 . $arr[0]['box_money'] . '
'; } if($arr[0]['dada_fee'] > 0){ $kw5 = ''; $len = 24 - strlen($arr[0]['dada_fee']); for ($q = 0; $q < $len; $q++) { $kw5 .= ' '; } $orderInfo .= '配送费:'.$kw5.$arr[0]['dada_fee'].'
'; } if($arr[0]['yhq_money2'] > 0){ $yhq_money2 = sprintf("%.2f",$arr[0]['yhq_money2']); $kw6 = ''; $len = 25 - strlen($yhq_money2); for ($q = 0; $q < $len; $q++) { $kw6 .= ' '; } $orderInfo .= '红包:'.$kw6.'-'.$yhq_money2.'
'; } $total = '合计:'.$arr[0]['m_money']; $user_name = $arr[0]['user_name']; if(strlen($user_name)>18){ $user_name=substr($user_name,0,18).'...'; } $str = $user_name . $total; $kw5 = ''; // $lenght = iconv("UTF-8", "GBK//IGNORE", $str); $total_len = 32 - mb_strwidth($str,'utf-8'); for ($q = 0; $q < $total_len; $q++) { $kw5 .= ' '; } $total_str = $user_name.$kw5.$total; $orderInfo .= $total_str.'
'; $orderInfo .= '送货地点:' . $arr[0]['address'] . '
'; $tel = substr_replace( $arr[0]['tel'], '****', 3, 4); $orderInfo .= '联系电话:' . $tel . '
'; $orderInfo .= '配送时间:' . $arr[0]['ps_time'] . '
'; if(!empty($arr[0]['note'])){ $orderInfo .= '备注:'.$arr[0]['note'].'

'; } //$orderInfo .= 'http://www.feieyun.com';//把解析后的二维码生成的字符串用标签套上即可自动生成二维码 return $orderInfo; } }