| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011 | <?php defined('BASEPATH') OR exit('No direct script access allowed');header("Access-Control-Allow-Origin: *");class Systemfout extends Start_Controller {	public function __construct(){		parent::__construct();		$this->load->library('session');		$this->load->_model('Model_whlabel','whlabel');		$this->load->_model('Model_warehouse','warehouse');		$this->load->_model('Model_productprice','productprice');		$this->load->_model('Model_excel','excel');		$this->load->_model('Model_fullorder','fullorder');		$this->load->_model('Model_fullordertt','fullordertt');		$this->load->_model('Model_fullordersmt','fullordersmt');		$this->load->_model('Model_outbound','outbound');		$this->load->_model('Model_express','express');		$this->load->_model('Model_shop','shop');		$this->load->_model('Model_typeclass','typeclass');		$this->load->_model('Model_country','country');		$this->load->_model('Model_kdniao','kdniao');		$this->load->_model('Model_notice','notice');		$this->load->_model('Model_dhl','dhl');		$this->load->_model('Model_dhlhz','dhlhz');		$this->load->_model('Model_usps','usps');		$this->load->_model('Model_fedex','fedex');		$this->load->_model('Model_fedex_cby','fedex_cby');		$this->load->_model('Model_ups','ups');		$this->load->_model('Model_ali','ali');		$this->load->_model('Model_dpd','dpd');		$this->load->_model('Model_shop','shop');		$this->load->_model('Model_user','user');		$this->load->_model('Model_whlabel','whlabel');		$this->load->_model('Model_specialstock','specialstock');		$this->load->_model('Model_ck','ck');		$this->load->_model('Model_whlabellabel','whlabellabel');		$this->load->_model('Model_apiyy','apiyy');		$this->load->helper('url');		$this->load->_model('Model_whlabel_fc','whlabel_fc');		$this->load->_model('Model_systemtransfer','systemtransfer');		$this->load->_model('Model_classid','classid');		$this->load->_model('Model_allocation','allocation');		$this->load->_model('Model_fullorderxw','fullorderxw');		$this->load->_model('Model_fullorderpaypal','fullorderpaypal');		$this->load->_model("Model_logic_ding","logic_ding");		$this->load->_model("Model_fedexv1",'fedexv1');	}	//定义方法的调用规则 获取URI第二段值    public function _remap($arg,$arg_array)    {		if($arg == 'fedexhz')        {             $this->_fedexhz();        }		else if($arg == 'fout')        {             $this->_fout($arg_array);        }		else if($arg == 'fouthb')//合并出库的        {             $this->_fouthb($arg_array);        }		else if($arg == 'excel')        {             $this->_excel($arg_array);        }		else if($arg == 'cpexcel')        {             $this->_cpexcel($arg_array);        }		else if($arg == 'orderyz')        {             $this->_orderyz();        }		else if($arg == 'hwyz')        {             $this->_hwyz();        }		else if($arg == 'outnumber')        {             $this->_outnumber();        }		else if($arg == 'hb')        {             $this->_hb();        }		else		{			 $this->_index();		}    }	public function _index()	{		$post = $this->input->post(NULL, TRUE);		$xw = '';		if(isset($_SESSION['api']))		{			$user = $this->user->get_api($_SESSION['api']);			$usp = $user;		    $fgshop = "";$sid = "";$wid="";$wtype="";		    $usersp = explode('|',trim($user['shop'],'|'));			$userwh = explode('|',trim($user['warehouse'],'|'));			foreach ($usersp as $value) 		    {				$fgshop .= " shop = ".$value." or";				$sid .= " id = ".$value." or";			}			foreach ($userwh as $value) 		    {				$wid .= " id = ".$value." or";				$wtype .= " type = ".$value." or";			}			if($user['userid'] == 'xw')			{				$xw = 1;			}		}		if(isset($post['page']))  		{		    $page = $this->input->post('page',true);		    $perpage = $this->input->post('perpage',true);			$timetk = $this->input->post('timetk',true);			$timetj = $this->input->post('timetj',true);			$shop = $this->input->post('shop',true);			$source = $this->input->post('source',true);			$orderinfo = $this->input->post('orderinfo',true);			$number = $this->input->post('number',true);			$library = $this->input->post('library',true);			$waybill = $this->input->post('waybill',true);			$express = $this->input->post('express',true);			$type = $this->input->post('type',true);			$lowe = $this->input->post('lowe',true);			$so = $this->input->post('so',true);			$librarytime = $this->input->post('librarytime',true);			$timetk = strtotime($timetk);			$timetj = strtotime($timetj);			$cxtime = 'id';			$where = "library!=3 and libraryconfirm=2 and print = 3 and (".rtrim($wtype,'or').")";			if($timetk && $timetj && $library == 1)            {				//$cxtime = 'reviewtime';                $where  .= "  and printtime > '$timetk - 180*24*3600' and printtime < '$timetj'";				$where  .= " and state != 217";				            }			else if($timetk && $timetj && $library == 2)            {				$cxtime = 'librarytime';                $where  .= " and librarytime > '$timetk' and librarytime < '$timetj'";            }			if($shop)            {                $where  .= " and shop = '$shop'";            }			if($number)            {                $where  .= " and number = '$number'";            }			if($library)            {                $where  .= " and library = '$library'";            }			if($waybill)            {                $where  .= " and waybill = '$waybill'";            }			if($express)            {				$where  .= " and express = '$express'";            }			if($orderinfo)            {                $where  .= " and orderinfo = '$orderinfo'";            }			if($type)            {                $where  .= " and type = '$type'";            }			if($lowe)            {                $where  .= " and shipremarks like '%$lowe%'";            }			if($so)            {                $where  .= " and shipremarks like '%$so%'";            }            //数据排序            $order_str = $cxtime." desc";            if(empty($page))		    {                $start = 0;		    	$perpage = 1;            }		    else		    {                $start = ($page - 1)*$perpage;            }            //取得信息列表            $info_list = $this->fullorder->find_all($where,'id,shop,type,orderinfo,number,waybill,express,print,library,librarytime,shipremarks',$order_str,$start,$perpage);			 //格式化数据            foreach ($info_list as $key=>$value)		    {				$shop = $this->shop->read($value['shop']);				$info_list[$key]['shop'] = $shop['shopname'];				if($value['waybill'] == '0')				{					$info_list[$key]['waybill'] = "";				}				$express = $this->express->read($value['express']);				$info_list[$key]['express'] = $express['servicename'];				$warehouse = $this->warehouse->read($value['type']);				$info_list[$key]['type'] = $warehouse['title'];				if($value['print'] == 1)				{					$info_list[$key]['print'] = '不可打印';				}				else if($value['print'] == 2)				{					$info_list[$key]['print'] = '未打印';				}				else if($value['print'] == 3)				{					$info_list[$key]['print'] = '已打印';				}				if($value['library'] == 1)				{					$info_list[$key]['library'] = '<em class="c">未出库</em>';				}				else if($value['library'] == 2)				{					$info_list[$key]['library'] = '<em class="c">已出库</em>';				}				else if($value['library'] == 3)				{					$info_list[$key]['library'] = '<em class="c">已退库</em>';				}				if($value['librarytime'] == '0')				{					$info_list[$key]['librarytime'] = '<em class="t"></em>';				}				else				{					$info_list[$key]['librarytime'] = '<em class="t">'.date('Y-m-d H:i',$value['librarytime']).'</em>';				}				$info_list[$key]['shipremarks'] = str_replace(array('<','>'),array('<','>'),$value['shipremarks']);            }			$info_listtt = $this->fullordertt->find_all($where,'id,shop,type,orderinfo,number,waybill,express,print,library,librarytime,shipremarks',$order_str,$start,$perpage);			 //格式化数据            foreach ($info_listtt as $key=>$value) 		    {				$shop = $this->shop->read($value['shop']);				$info_listtt[$key]['shop'] = $shop['shopname'];				if($value['waybill'] == '0')				{					$info_listtt[$key]['waybill'] = "";				}				$express = $this->express->read($value['express']);				$info_listtt[$key]['express'] = $express['servicename'];				$warehouse = $this->warehouse->read($value['type']);				$info_listtt[$key]['type'] = $warehouse['title'];				if($value['print'] == 1)				{					$info_listtt[$key]['print'] = '不可打印';				}				else if($value['print'] == 2)				{					$info_listtt[$key]['print'] = '未打印';				}				else if($value['print'] == 3)				{					$info_listtt[$key]['print'] = '已打印';				}				if($value['library'] == 1)				{					$info_listtt[$key]['library'] = '<em class="c">未出库</em>';				}				else if($value['library'] == 2)				{					$info_listtt[$key]['library'] = '<em class="c">已出库</em>';				}				else if($value['library'] == 3)				{					$info_listtt[$key]['library'] = '<em class="c">已退库</em>';				}				if($value['librarytime'] == '0')				{					$info_listtt[$key]['librarytime'] = '<em class="t"></em>';				}				else				{					$info_listtt[$key]['librarytime'] = '<em class="t">'.date('Y-m-d H:i:s',$value['librarytime']).'</em>';				}            }			$info_listxw = $this->fullorderxw->find_all($where,'id,shop,type,orderinfo,number,waybill,express,print,library,librarytime,shipremarks',$order_str,$start,$perpage);			 //格式化数据            foreach ($info_listxw as $key=>$value) 		    {				$shop = $this->shop->read($value['shop']);				$info_listxw[$key]['shop'] = $shop['shopname'];				if($value['waybill'] == '0')				{					$info_listxw[$key]['waybill'] = "";				}				$express = $this->express->read($value['express']);				$info_listxw[$key]['express'] = $express['servicename'];				$warehouse = $this->warehouse->read($value['type']);				$info_listxw[$key]['type'] = $warehouse['title'];				if($value['print'] == 1)				{					$info_listxw[$key]['print'] = '不可打印';				}				else if($value['print'] == 2)				{					$info_listxw[$key]['print'] = '未打印';				}				else if($value['print'] == 3)				{					$info_listxw[$key]['print'] = '已打印';				}				if($value['library'] == 1)				{					$info_listxw[$key]['library'] = '<em class="c">未出库</em>';				}				else if($value['library'] == 2)				{					$info_listxw[$key]['library'] = '<em class="c">已出库</em>';				}				else if($value['library'] == 3)				{					$info_listxw[$key]['library'] = '<em class="c">已退库</em>';				}				if($value['librarytime'] == '0')				{					$info_listxw[$key]['librarytime'] = '<em class="t"></em>';				}				else				{					$info_listxw[$key]['librarytime'] = '<em class="t">'.date('Y-m-d H:i:s',$value['librarytime']).'</em>';				}            }			$info_listsmt = $this->fullordersmt->find_all($where." and mergeid = '0'",'id,shop,type,orderinfo,number,waybill,express,print,library,librarytime,shipremarks',$order_str,$start,$perpage);			 //格式化数据            foreach ($info_listsmt as $key=>$value) 		    {				$shop = $this->shop->read($value['shop']);				$info_listsmt[$key]['shop'] = $shop['shopname'];				if($value['waybill'] == '0')				{					$info_listsmt[$key]['waybill'] = "";				}				$express = $this->express->read($value['express']);				$info_listsmt[$key]['express'] = $express['servicename'];				$warehouse = $this->warehouse->read($value['type']);				$info_listsmt[$key]['type'] = $warehouse['title'];				if($value['print'] == 1)				{					$info_listsmt[$key]['print'] = '不可打印';				}				else if($value['print'] == 2)				{					$info_listsmt[$key]['print'] = '未打印';				}				else if($value['print'] == 3)				{					$info_listsmt[$key]['print'] = '已打印';				}				if($value['library'] == 1)				{					$info_listsmt[$key]['library'] = '<em class="c">未出库</em>';				}				else if($value['library'] == 2)				{					$info_listsmt[$key]['library'] = '<em class="c">已出库</em>';				}				else if($value['library'] == 3)				{					$info_listsmt[$key]['library'] = '<em class="c">已退库</em>';				}				if($value['librarytime'] == '0')				{					$info_listsmt[$key]['librarytime'] = '<em class="t"></em>';				}				else				{					$info_listsmt[$key]['librarytime'] = '<em class="t">'.date('Y-m-d H:i:s',$value['librarytime']).'</em>';				}            }		    $total = $this->fullorder->find_count($where);			$total += $this->fullordertt->find_count($where);			$total += $this->fullorderxw->find_count($where);			$total += $this->fullordersmt->find_count($where);		    $pagenum = ceil($total/$perpage);		    $over = $total-($start+$perpage);		    $rows = array('total'=>$total,'over'=>$over,'pagenum'=>$pagenum,'rows'=>(array_merge($info_list,$info_listtt,$info_listxw,$info_listsmt)));		    echo json_encode($rows);exit;		}		if(isset($_SESSION['api']))		{			$wlshop = $this->shop->find_all('1=1 and '.rtrim($sid,'or'));			$warehouse = $this->warehouse->find_all('1=1 and '.rtrim($wid,'or'),"*","px asc");		    $this->data['wlshop'] = $wlshop;		    $this->data['warehouse'] = $warehouse;		}		$this->data['xw'] = $xw;		$this->_Template('systemfout',$this->data);	}	public function _fout()	{		$post = $this->input->post(NULL, TRUE);		if(isset($post['order']))  		{			$time = time();			$order = $this->input->post('order',true);			$weight = $this->input->post('weight',true);			if(!isset($weight))//测试没问题后可以删			{				$weight = '';			}			if(substr($order,0,3) == '788' && substr($order,-4,4) == '0430')//Fedex联邦			{				$order = substr($order,0,12);			}			if(strlen($order) == '34')//联邦杭州超长运单截取			{				$order = substr($order,22,12);			}			if(!$order)			{				echo json_encode(array('msg'=>'出库信息不能为空!','success'=>false));exit;			}			if(strlen($order) == 30)			{				$order = substr($order, 8);			}			$fullorder_name = 'fullorder';$outtype = 1;			$y = $this->fullorder->get_waybill($order);			if(!$y)			{				$y = $this->fullorder->get_number($order);				$outtype = 2;				if(!$y)				{					$fullorder_name = 'fullordersmt';$outtype = 1;					$y = $this->fullordersmt->get_waybill($order);					if(!$y)				    {						$y = $this->fullordersmt->get_number($order);						$outtype = 2;						if(!$y)						{							$fullorder_name = 'fullordertt';$outtype = 1;							$y = $this->fullordertt->get_waybill($order);							if(!$y)				    		{								$y = $this->fullordertt->get_number($order);								$outtype = 2;								if(!$y)				        			{										$fullorder_name = 'fullorderxw';$outtype = 1;										$y = $this->fullorderxw->get_waybill($order);										if(!$y)				    					{											$y = $this->fullorderxw->get_number($order);											$outtype = 2;											if(!$y)				        					{												echo json_encode(array('msg'=>'无此数据','success'=>false));exit;											}										}									}							}						}											}				}			}			if($y['mergeid'] == '1')			{				$y = $this->$fullorder_name->read($y['merge']);			}			$express = $this->express->read($y['express']);			if($y['state'] == 216 && $fullorder_name == 'fullordersmt')			{				$y['librarynot'] = '客户已取消!';			}			if($y['print'] != 3 || $y['libraryconfirm'] == 1 || $y['state'] == 214 || $y['state'] == 217 || $y['state'] == 283 || $y['state'] == 206 || $y['state'] == 205 || $y['state'] == 204 || $y['state'] == 210 || $y['state'] == 211 || $y['state'] == 212 || ($y['state'] == 216 && $fullorder_name == 'fullordersmt'))//独立站216先关了			{				echo json_encode(array('msg'=>'禁止出库!'.$y['librarynot'],'success'=>false));exit;			}			if($y['library'] > 1)			{				echo json_encode(array('msg'=>'此数据 '.date('Y-m-d H:i:s',$y['librarytime']).' 已操作','success'=>false));exit;			}			if($express['out'] != 3)			{				if($express['out'] != $outtype)				{					$smlx = ($express['out']=='1')?'运单':'发货单';					echo json_encode(array('msg'=>'扫描类型错误!此单需要扫描'.$smlx,'success'=>false));exit;				}			}			if($y['type'] != 7 && $y['waybill'] != '' && $y['printtype'] == '1')			{				$y['waybill'] = trim($y['waybill'],' ');			    if(strlen($y['waybill']) == 12 && $y['express'] != 24 && $y['express'] != 31 && $y['express'] != 38 && $y['express'] != 41 && $y['express'] != 6 && $y['express'] != 43 && $y['express'] != 48 && $y['express'] != 50 && $y['express'] != 63)				{					echo json_encode(array('msg'=>'出库物流和系统不匹配,请联系梦体解决'.$y['express'].'-1','success'=>false));exit;				}				else if(strlen($y['waybill']) == 10 && $y['express'] != 1 && $y['express'] != 37 && $y['express'] != 49 && $y['express'] != 42)				{					echo json_encode(array('msg'=>'出库物流和系统不匹配,请联系梦体解决'.$y['express'].'-2','success'=>false));exit;				}				else if(strlen($y['waybill']) == 18 && $y['express'] != 3 && $y['express'] != 66 && $y['express'] != 67)				{					echo json_encode(array('msg'=>'出库物流和系统不匹配,请联系梦体解决'.$y['express'].'-3','success'=>false));exit;				}			}			if(stripos($weight,',') !== false){               $tmp_arr = explode(",",$weight);                $weight = end($tmp_arr);                                $numweight = (float)$weight;                $weight = $numweight."kg";            }			$numweight = str_replace('kg','',$weight);// 			if(($y['express'] == '24' || $y['express'] == '3' || $y['express'] == '28' || $y['express'] == '33' || $y['express'] == '42') && $y['type'] != 6)//杭州除外// 			{// 				if($weight == '' || $numweight < '0.1' || !is_numeric($numweight))// 				{// 					echo json_encode(array('msg'=>'此单需要称重!','success'=>false));exit;// 				}// 				$yzweight = explode('.',$numweight);// 				if($yzweight[0] == '')// 				{// 					echo json_encode(array('msg'=>'重量错误,请重新称重!','success'=>false));exit;// 				}// 				if($numweight < ($y['jweight']/1000))// 				{// 					echo json_encode(array('msg'=>'重量小于净重,请重新称重!','success'=>false));exit;// 				}// 				if($numweight -($y['jweight']/1000) > 0.9 && $y['number'] != 'QQS-30401-002')// 				{// 					echo json_encode(array('msg'=>'称重重量和净重相差过大,请找成会或梦体处理!','success'=>false));exit;// 				}// 				if($numweight > '0.98' &&  $y['express'] == '3')// 				{// 					echo json_encode(array('msg'=>'UPS大于0.98公斤需要拆包!','success'=>false));exit;// 				}// 				if($numweight > '2' &&  $y['express'] == '37')// 				{// 					echo json_encode(array('msg'=>'杭州DHL大于2公斤需要联系店员!','success'=>false));exit;// 				}// 				if($numweight >= '10' && ($y['express'] == '24' || $y['express'] == '31'))// 				{// 					echo json_encode(array('msg'=>'联邦不能大于10公斤!','success'=>false));exit;// 				}// 			}                        //根据要求 USPS-USA  2  FEDEX-US2 63 USPS-US2 64  这三个快递方式除外的所有快递都需要称重再发货  或者说是【国内发货】的都需要称重            //还有翔文仓库的 不执行            //源代码是           	//所有快递必须称重		        	//所有快递必须称重	翔文除外                    	        	$this->logic_ding->sendToDing("检测订单".$y['number']."称重".$numweight."快递公司".$y['express']."-".$weight."[".$numweight."]");			if(!in_array($y['express'],[2,39,43,44,45,47,48,49,55,61,63,64,65])){				if($weight == '' || $numweight < '0.1' || !is_numeric($numweight))				{					echo json_encode(array('msg'=>'此单需要称重!','success'=>false));exit;				}				$yzweight = explode('.',$numweight);				if($yzweight[0] == '')				{					echo json_encode(array('msg'=>'重量错误,请重新称重!','success'=>false));exit;				}				if(empty($numweight)){				    echo json_encode(array('msg'=>'此单需要称重2!','success'=>false));exit;				}				//$this->logic_ding->sendToDing("检测订单---------------------标记需要认证的东西".$y['number']);			}				//$this->logic_ding->sendToDing("检测订单".$y['number']."称重".$numweight."快递公司".$y['express']);			$express_info = $this->express->read($y['express']);			if(empty($express_info)){				echo json_encode(array('msg'=>'该快递信息异常,请联系技术!','success'=>false));exit;			}    		$weight_limit = $express_info['weight_limit']*1;	        if($weight_limit  > 0){                    				$yzweight = explode('.',$numweight);    				if($yzweight[0] == '')    				{    					echo json_encode(array('msg'=>'重量错误,请重新称重!','success'=>false));exit;    				}                    if($numweight < ($y['jweight']/1000)){        			    echo json_encode(array('msg'=>'重量小于净重,请重新称重!','success'=>false));exit;        			}    				//Fedex(杭州),UPS,DHL官方-美国 需要判断实际重量和净重差 其他快递不需要    				if(in_array($y['express'],[3,24,42])){    				   	//规定实际重量不允许超过 净重为1kg        				if($numweight -($y['jweight']/1000) > 1 )        				{        					echo json_encode(array('msg'=>'称重重量和净重相差过大,请找成会处理!','success'=>false));exit;        				}    				}    			    				if($weight_limit < $numweight){    					echo json_encode(array('msg'=>$express['servicename'].'大于'.$weight_limit.'公斤需要拆包!','success'=>false));exit;    				}            }									if(((time() - $y['printtime']) > (15*24*3600) || $y['printtime'] < 1590211800) && $y['express'] == '24' && $y['type'] != 6)//杭州店铺除外			{				//echo json_encode(array('yd'=>1,'id'=>$y['id'],'express'=>$y['express'],'name'=>$fullorder_name,'success'=>true));exit;			}			if((time() - $y['printtime']) > (6*24*3600) && $y['express'] == '3' && $y['type'] != 6)//杭州店铺除外			{				//echo json_encode(array('yd'=>1,'id'=>$y['id'],'express'=>$y['express'],'name'=>$fullorder_name,'success'=>true));exit;				echo json_encode(array('msg'=>'此运单过期无法出库,请联系成会处理!','success'=>false));exit;			}			if((time() - $y['printtime']) > (7*24*3600) && $y['express'] == '37' && $y['type'] != 6)//杭州店铺除外			{				//echo json_encode(array('yd'=>1,'id'=>$y['id'],'express'=>$y['express'],'name'=>$fullorder_name,'success'=>true));exit;			}						$this->db->trans_begin();			$warehouse = $this->warehouse->read($y['type']);			$bdck = $warehouse['bdck'];			if($warehouse['zd'] == '1')			{				if($warehouse['bdck'] == '')				{					echo json_encode(array('msg'=>'仓库设置错误!','success'=>false));exit;				}				$wh = $this->_fout_db($y,$warehouse,$bdck);				if($wh['fh'] == 2)				{					$kcyz = $this->ck->get_kc($y['state'],$warehouse,$y['shop'],$y['number'],$y['whlabel'],$y['fpdata']);						if($kcyz['t'] == '0')			    	{						if($kcyz['fpdata'] != '')						{				    	$x['whlabel'] = $kcyz['whlabel'];				    	$x['fpdata'] = $kcyz['fpdata'];						$y['whlabel'] = $x['whlabel'];						$this->$fullorder_name->save($x,$y['id']);						}			   		}					$wh = $this->_fout_db($y,$warehouse,$bdck);					if($wh['fh'] == 2)					{						echo json_encode(array('msg'=>'库存占用量与实际出库量不符!','success'=>false));exit;					}				}				foreach ($wh['sj'] as $v)		        {					$this->$bdck->save(array('state'=>1,'cktype'=>1,'orderinfo'=>$y['orderinfo'],'waybill'=>$y['waybill'],'outk'=>$time,'time'=>$time),$v['id']);				}							}			/**			if($warehouse['zd'] == '1' && stripos($y['whlabel'],'z|') === false)			{				$whlabel = $this->whlabel->find_all("zd = '".$y['number']."' and warehouse = '".$y['type']."' and (state = '0' or state = '9')");				$cpsl = 0;				$pp = explode('|',trim($y['whlabel'],'|'));				foreach ($pp as $va)		        {					$num = explode('-',$va);					$cpsl += $num[1];				}				if(count($whlabel) != $cpsl)				{					echo json_encode(array('msg'=>'库存占用量与实际出库量不符','success'=>false));exit;				}				foreach ($whlabel as $v)		        {					$this->whlabel->save(array('state'=>1,'orderinfo'=>$y['orderinfo'],'waybill'=>$y['waybill'],'outk'=>$time,'time'=>$time),$v['id']);				}			}			if($warehouse['zd'] == '1' && stripos($y['whlabel'],'z|') !== false)			{				$wh = $this->specialstock->find_all("zd = '".$y['number']."' and state = '0'");				$cpsl = 0;				$pp = explode('|',trim($y['whlabel'],'|'));				foreach ($pp as $va)		        {					$num = explode('-',$va);					if(stripos($num[2],'z') !== false)//如果是特殊库存					{					    $cpsl += $num[1];					}				}				if(count($wh) != $cpsl)				{					echo json_encode(array('msg'=>'库存占用量与实际出库量不符','success'=>false));exit;				}				foreach ($wh as $v)		        {					if(!$this->specialstock->save(array('state'=>1,'orderinfo'=>$y['orderinfo'],'waybill'=>$y['waybill'],'outk'=>$time,'time'=>$time),$v['id']))					{						echo json_encode(array('msg'=>'出库失败,请重试','success'=>false));exit;						}				}			}			**/			/**			if($y['dbapi'] == 99 && $y['scapi'] == 99)			{			    $d = $this->apiyy->get_chd($y);			    if($d['Data'][0]['m_isSucess'] != 1)			    {				    echo json_encode(array('msg'=>'用友出库失败:'.$d['Data'][0]['m_errorMsg'],'success'=>false));exit;			    }			}			$systemtransfer = $this->systemtransfer->find_all("number = '".$y['number']."'");			if(isset($systemtransfer[0]))			{				foreach ($systemtransfer as $v)		        {					if($v['dbapi'] != 99)					{						echo json_encode(array('msg'=>'此订单货物:'.$v['pm'].'没有成功扫布标入库,无法出库!','success'=>false));exit;					}				}				$y['ts'] = count($systemtransfer);				 $d = $this->apiyy->get_chd($y);			    	if($d['Data'][0]['m_isSucess'] != 1)			    	{						echo json_encode(array('msg'=>'用友出库失败:'.$d['Data'][0]['m_errorMsg'],'success'=>false));exit;			    	}			}			**/						$shop = $this->shop->read($y['shop']);			if($express['printcode'] == "DHLUSA" && $y['waybill'] != '')			{				$type = $this->typeclass->read($shop['type']);				$y['shoptype'] = $type['title'];				$y['weight'] = $weight;				$d = $this->dhl->get_data_9610($y);				if($d != 1)				{					$this->allocation->insert(array('order'=>1,'title'=>$y['number'],'content'=>$d));					echo json_encode(array('msg'=>'9610失败,'.$d,'success'=>false));exit;				}				$this->allocation->insert(array('order'=>9610,'title'=>$y['number']));			}			if($fullorder_name == 'fullordersmt')			{				$stt = ($y['waybill']!='')?209:$y['state'];				$post = array('library'=>2,'state'=>$stt,'librarytime'=>$time,'weight'=>$weight,'dbapi'=>0);				/**			    if($this->$fullorder_name->save(array('library'=>2,'state'=>$stt,'librarytime'=>$time,'weight'=>$weight),$y['id']))        	    {         		    echo json_encode(array('success'=>true));exit;       	 	    }       		    else        	    {           		    echo json_encode(array('msg'=>'出库失败,请重试','success'=>false));exit;        	    }				**/			}			else if(($fullorder_name == 'fullordertt' || $fullorder_name == 'fullorderxw' || $fullorder_name == 'fullorder') && $y['source'] == 1)			{				/**				if($this->$fullorder_name->save(array('library'=>2,'librarytime'=>$time,'weight'=>$weight),$y['id']))        	    {         		    echo json_encode(array('success'=>true));exit;       	 	    }       		    else        	    {           		    echo json_encode(array('msg'=>'出库失败,请重试','success'=>false));exit;        	    }				**/				$post = array('library'=>2,'state'=>216,'librarytime'=>$time,'weight'=>$weight,'dbapi'=>0);			}			else			{				/**				if($this->$fullorder_name->save(array('library'=>2,'librarytime'=>$time,'weight'=>$weight),$y['id']))        	    {         		    echo json_encode(array('success'=>true));exit;       	 	    }       		    else        	    {           		    echo json_encode(array('msg'=>'出库失败,请重试','success'=>false));exit;        	    }				**/				$post = array('library'=>2,'librarytime'=>$time,'weight'=>$weight,'dbapi'=>0);			}			/**			if($fullorder_name == 'fullorder')			{				$orderinfo = preg_replace('/^' . preg_quote($y['shop'], '/') . '/', '', $y['orderinfo']);				$post['incrementId'] = $orderinfo;				$post['trackingNumber'] = $y['waybill'];				$ex = $this->express->read($y['express']);				$post['carrier'] = $ex['iscode'];				$url = 'https://www.romandhair.com/applepay/payment/addTrack';				$ch = curl_init();				curl_setopt($ch,CURLOPT_URL,$url);				curl_setopt($ch, CURLOPT_POST, 1);				curl_setopt($ch, CURLOPT_HEADER, 0);				curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);				curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);				curl_setopt($ch, CURLOPT_BINARYTRANSFER, 1);				curl_setopt($ch, CURLOPT_POSTFIELDS,http_build_query($post));				curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);				curl_setopt($ch,CURLOPT_CONNECTTIMEOUT,1800000);				$res = curl_exec($ch);				curl_close($ch);				$res = json_decode($res,true);				if($res['success'] == 0)				{					$this->fullorderpaypal->insert(array('orderinfo'=>$y['orderinfo'],'waybill'=>$y['waybill'],'time'=>$time,'cw'=>$res['msg']));//失败				}				else				{					$this->fullorderpaypal->insert(array('orderinfo'=>$y['orderinfo'],'waybill'=>$y['waybill'],'time'=>$time,'type'=>1));				}			}			**/			if($outtype == 2 && $y['printnumber'] > 1)			{				$p = json_encode($post);				echo json_encode(array('msg'=>'该单共打印过'.$y['printnumber'].'次,请注意核对当前发货单是否是最新发货单!','outnumber'=>$y['id'],'post'=>$p,'fullorder_name'=>$fullorder_name,'success'=>false));exit;			}			$this->$fullorder_name->save($post,$y['id']);						//合并订单自动发货			$hb = $this->$fullorder_name->find_all("merge = '".$y['id']."' and id != '".$y['id']."'");			$post['waybill'] = $y['waybill'];			$post['express'] = $y['express'];			$post['printtype'] = $y['printtype'];			$post['ioss'] = $y['ioss'];			$post['review'] = 6;			$post['bx'] = $y['bx'];			$post['qm'] = $y['qm'];			$post['js'] = $y['js'];			//$post['state'] = 216;			$post['print'] = $y['print'];			$post['printtime'] = $y['printtime'];			$post['library'] = 2;			$post['librarytime'] = $time;			$post['libraryconfirm'] = 2;			$post['librarynot'] = '';			foreach ($hb as $v)		    {				$post['state'] = $v['state'];				$vshop = $this->shop->read($v['shop']);				$vwarehouse = $this->warehouse->read($v['type']);				$this->$fullorder_name->save($post,$v['id']);				//2025年1月25日发现翔文合并订单发现此问题				if($warehouse['zd'] == '1'){					$wh = $this->_fout_db($v,$warehouse,$bdck);					foreach ($wh['sj'] as $vv)					{						$this->$bdck->save(array('state'=>1,'cktype'=>1,'orderinfo'=>$v['orderinfo'],'waybill'=>$y['waybill'],'outk'=>$time,'time'=>$time),$vv['id']);					}				}								// $wh = $this->_fout_db($v,$warehouse,$bdck);				// foreach ($wh['sj'] as $vv)		  //      {				// 	$this->$bdck->save(array('state'=>1,'cktype'=>1,'orderinfo'=>$v['orderinfo'],'waybill'=>$y['waybill'],'outk'=>$time,'time'=>$time),$vv['id']);				// }				//$this->ck->get_kc($post['state'],$vwarehouse,$vshop,$v['number'],$v['whlabel'],$v['fpdata']);			}			if ($this->db->trans_status() === TRUE)        	{				$this->db->trans_commit();				echo json_encode(array('success'=>true));			}			else			{				$this->db->trans_rollback();				echo json_encode(array('msg'=>'出库失败,请重试','success'=>false));			}		}	}		public function _outnumber()//对比占单是否正确	{		$post = $this->input->post(NULL, TRUE);		if(isset($post['outnumber']))  		{			$post = $this->input->post('post',true);			$fullorder_name = $this->input->post('fullorder_name',true);			$outnumber = $this->input->post('outnumber',true);			$post = json_decode($post,true);			$this->$fullorder_name->save($post,$outnumber);		}	}	public function _fout_db($y,$warehouse,$bdck)//对比占单是否正确	{		$wh = $this->$bdck->find_all("zd = '".$y['number']."' and warehouse = '".$y['type']."' and (state = '0' or state = '9')");		$cpsl = 0;		$pp = explode('|',trim($y['whlabel'],'|'));		foreach ($pp as $va)		{			$num = explode('-',$va);			if(isset($num[2]))			{			    if(stripos($num[2],$warehouse['hz']) !== false)			    {				    $cpsl += $num[1];			    }			}		}		if(count($wh) == $cpsl)		{		    return array('fh'=>1,'sj'=>$wh);		}		else		{			return array('fh'=>2);		}	}		public function _fedexhz()    {		$post = $this->input->post(NULL, TRUE);		if(isset($post['id']))		{			$id = $this->input->post('id',true);			$fullorder_name = $this->input->post('name',true);			$express = $this->input->post('express',true);			$express = $this->express->read($express);			$fullorder = $this->$fullorder_name->read($id);			if($fullorder['type'] == '2')			{				$fullorder['type'] = 1;			}			$time = time();			$fullorder = $this->_text($fullorder);//获取所需信息			$oldprinttime = ($fullorder['printtime'] > 0)?$fullorder['oldprinttime'].$fullorder['printtime'].'-':'';			$fullorder['printtime'] = date('m-d H:i',$time);//打印用时间、发货单用,不能删			$time = time();			if($express['printcode'] == "FEDEXGF")			{			    //$barcode = $this->fedex->get_data($fullorder);//获取联邦快递信息			   //升级的api				$barcode = $this->fedexv1->get_data($fullorder);//获取联邦快递信息			    if($barcode['x'] == 1)			    {				    $bctime = date('Ymd',$time);				    $Hwaybill = $barcode['waybill'];					// $Hyd = $this->_pdf($barcode['label'],'y-'.$Hwaybill,$bctime);				    // $Hfp = $this->_pdf($barcode['invoice'],'f-'.$Hwaybill,$bctime);//开通ETD模式,保留PDF,不需要打印				    $Hyd = $this->_pdfurl($barcode['label'],'y-'.$Hwaybill,$bctime);				    $Hfp = $this->_pdfurl($barcode['invoice'],'f-'.$Hwaybill,$bctime);//开通ETD模式,保留PDF,不需要打印				    if(isset($barcode['label']) && isset($Hwaybill))				    {					    if($fullorder['waybill'] != "")							{								$oldwaybill = $fullorder['oldwaybill'].'-'.date('Ymd',$time).'/'.$fullorder['waybill'];							}							else							{								$oldwaybill = $fullorder['oldwaybill'];							}							$oldwaybill .= '-'.$bctime.'/'.$Hwaybill;					    $fullorder['printnumber'] = $fullorder['printnumber'] +1;//不能删					    if($this->$fullorder_name->save(array('waybill'=>$Hwaybill,'printtime'=>$time,'printnumber'=>$fullorder['printnumber'],'oldwaybill'=>$oldwaybill,'oldprinttime'=>$oldprinttime),$fullorder['id']))					    {					    	$warehouse = $this->warehouse->read($fullorder['type']);							$text = array();							$text['yd'] = base_url().'data/pdf/'.$bctime.'/y-'.$Hwaybill.'.pdf';							$text['number'] = $fullorder['number'];							$text['mode'] = '95';							$text['pdfnum'] = 1;							$rows = array('text'=>$text);			   				echo json_encode(array('rows'=>($rows),'success'=>true));exit;					    }					    else					    {						    echo json_encode(array($fullorder['number'].'msg'=>'打印错误,请联系店员','cw'=>'写入数据库错误','success'=>false));exit;					    }				    }			    }			    else			    {				    echo json_encode(array('msg'=>'打印错误,请联系店员','cw'=>$barcode['Description'],'success'=>false));exit;			    }			}			else if($express['printcode'] == "UPS")//接口UPS暂时不打			{				echo json_encode(array('msg'=>'此订单超期无法出库,请联系成会处理','success'=>false));exit;				$barcode = $this->ups->get_data($fullorder);//获取快递信息				if($barcode['x'] == 1)				{					$bctime = date('Ymd',$time);					$Hwaybill = $barcode['waybill'];					$Hyd = $this->_pdfurl($barcode['label'],'y-'.$Hwaybill,$bctime);					if(isset($barcode['label']) && isset($Hwaybill))					{						if($fullorder['waybill'] != "")							{								$oldwaybill = $fullorder['oldwaybill'].'-'.date('Ymd',$time).'/'.$fullorder['waybill'];							}							else							{								$oldwaybill = $fullorder['oldwaybill'];							}							$oldwaybill .= '-'.$bctime.'/'.$Hwaybill;						$fullorder['printnumber'] = $fullorder['printnumber'] +1;//不能删						if($this->$fullorder_name->save(array('waybill'=>$Hwaybill,'libraryconfirm'=>2,'librarynot'=>'','printtime'=>$time,'printnumber'=>$fullorder['printnumber'],'print'=>3,'oldwaybill'=>$oldwaybill,'oldprinttime'=>$oldprinttime),$va[$n]))				   		{							$type = 1;							$text = array('yd'=>'data/pdf/'.$bctime.'/y-'.$Hwaybill.'.pdf','data'=>$fullorder,'id'=>$fullorder['id'],'pt'=>$fullorder_name);						}					}				}				else				{					echo json_encode(array('msg'=>$fullorder['number'].'打印错误,请联系店员','cw'=>$barcode['Description'],'success'=>false));exit;				}			}			else if($express['printcode'] == "DHLHZ")//如果打印过那么重新获取运单			{				 $barcode = $this->dhlhz->get_data($fullorder);//获取DHL快递信息				 if($barcode['c'] == 1)				 {					$bctime = date('Ymd',$time);					$Hwaybill = $barcode['data']['waybill'];					$Hfp = $this->_pdf($barcode['data']['fp'],'f-'.$Hwaybill,$bctime);					$Hyd = $this->_pdf($barcode['data']['yd'],'y-'.$Hwaybill,$bctime);					if(isset($Hfp) && isset($Hyd) && isset($Hwaybill))					{						if($fullorder['waybill'] != "")						{							$oldwaybill = $fullorder['oldwaybill'].'-'.date('Ymd',$time).'/'.$fullorder['waybill'];						}						else						{							$oldwaybill = $fullorder['oldwaybill'];						}						$oldwaybill .= '-'.$bctime.'/'.$Hwaybill;						$fullorder['printnumber'] = $fullorder['printnumber'] +1;//不能删d						if($this->$fullorder_name->save(array('waybill'=>$Hwaybill,'printtime'=>$time,'printnumber'=>$fullorder['printnumber'],'oldwaybill'=>$oldwaybill,'oldprinttime'=>$oldprinttime),$fullorder['id']))					    {					    	$warehouse = $this->warehouse->read($fullorder['type']);							$text = array();							$text['yd'] = base_url().'data/pdf/'.$bctime.'/y-'.$Hwaybill.'.pdf';							$text['number'] = $fullorder['number'];							$text['mode'] = '95';							$text['pdfnum'] = 1;							$rows = array('text'=>$text);			   				echo json_encode(array('rows'=>($rows),'success'=>true));exit;					    }					}				}				else				{					echo json_encode(array('msg'=>$fullorder['number'].'打印错误,请联系店员','cw'=>$barcode['Description'],'success'=>false));exit;				}			}			else			{				echo json_encode(array('msg'=>'此订单超期无法出库,请联系成会或者梦体处理','success'=>false));exit;			}		}	}		public function _text($fullorder)    {		/** 发票地址信息暂时无用 		$fullorder['baddress'] = explode(',',$fullorder['baddress']);		$fullorder['baddress'] = array_reverse($fullorder['baddress']);		$fullorder['baddress'][1] = $country['ename'];		**/		//获取所用相关信息		$warehouse = $this->warehouse->read($fullorder['type']);		$country = $this->country->read($fullorder['country']);//订单国家信息		$fcountry = $this->country->read($warehouse['country']);//仓库国家信息		$warehouse['country'] = $fcountry['ename'];//仓库国家名		$warehouse['lb'] = $fcountry['lb'];//仓库国家编码		$fullorder['warehouse'] = $warehouse;//仓库数据加入订单		$fullorder['lb'] = $country['lb'];//订单国家编码加入		$fullorder['country'] = $country['ename'];//订单国家名		$fullorder['zhou'] = $country['continent'];//所属州		$express = $this->express->read($fullorder['express']);		$fullorder['express'] = $express['servicename'];		$fullorder['account'] = $express['account'];		$fullorder['printcode'] = $express['printcode'];		$fullorder['time'] = date('Y-m-d',time());		$fullorder['times'] = date('Y-m-d H:i',time());		$fullorder['sbbm']= ($fullorder['sbpm'] == 'Hair Sample') ? 67042000 : 67041100;		$fullorder['address'] = str_replace(array('&'),array('&'),$fullorder['address']);		$fullorder['address2'] = str_replace(array('&'),array('&'),$fullorder['address2']);		$shop = $this->shop->read($fullorder['shop']);		$fullorder['shop'] = $shop['shopname'];		return $fullorder;    }		public function _lowe()	{		$post = $this->input->post(NULL, TRUE);		if(isset($post['lowe']))  		{		    $lowe = $this->typeclass->find_all('classid = 15 and id != 105 and id != 107 and id != 108 and id != 112 and id != 114 and id != 115 and id != 116 and id != 117 and id != 118 and id != 119 and id != 120 and id != 121 and id != 122 and id != 123 and id != 124 and id != 125 and id != 292 and id != 63 and id != 289 and id != 290 and id != 181 and id != 273 and id != 148 and id != 38 and id != 291 and id != 55 and id != 271 and id != 285 and id != 186 and id != 187 and id != 188 and id != 189');		    echo json_encode(array('msg'=>$lowe));exit;		}	}	public function _pdf($pdf,$title,$bctime)    {    	$pdf_path = './data/pdf/'.$bctime.'/';        $file_base64 = $pdf;         $file_base64 = preg_replace('/data:.*;base64,/i', '', $file_base64);          $file_base64 = base64_decode($file_base64);		if(!is_dir($pdf_path))mkdir($pdf_path,0777); //上传目录不存在则创建        file_put_contents($pdf_path.$title.'.pdf',$file_base64);		return $bctime;    }	public function _pdfurl($pdf,$title,$bctime)    {    	$pdf_path = './data/pdf/'.$bctime.'/';        $pdf = fopen($pdf,"r");		if(!is_dir($pdf_path))mkdir($pdf_path,0777); //上传目录不存在则创建        file_put_contents($pdf_path.$title.'.pdf',$pdf);		return $bctime;    }		public function _excel()	{		$xw = '';		if(isset($_SESSION['api']))		{			$user = $this->user->get_api($_SESSION['api']);			$usp = $user;		    $fgshop = "";$sid = "";$wid="";$wtype="";		    $usersp = explode('|',trim($user['shop'],'|'));			$userwh = explode('|',trim($user['warehouse'],'|'));			foreach ($usersp as $value) 		    {				$fgshop .= " shop = ".$value." or";				$sid .= " id = ".$value." or";			}			foreach ($userwh as $value) 		    {				$wid .= " id = ".$value." or";				$wtype .= " type = ".$value." or";			}			if($user['userid'] == 'xw')			{				$xw = 1;			}		}		if(isset($_GET['fexcel']))  		{			$dowid = $this->input->get('a');			$wid = "";			if($dowid != "")			{				$id_arr =  explode(',',rtrim($dowid,','));				foreach ($id_arr as $v) 		        {                    $wid  .= " id = '$v' or";                }				$wid = " and".rtrim($wid,'or');			}		    $t = $this->input->get('t',true);			$timetk = $this->input->get('timetk',true);			$timetj = $this->input->get('timetj',true);			$shop = $this->input->get('shop',true);			$source = $this->input->get('source',true);			$orderinfo = $this->input->get('orderinfo',true);			$number = $this->input->get('number',true);			$library = $this->input->get('library',true);			$waybill = $this->input->get('waybill',true);			$express = $this->input->get('express',true);			$type = $this->input->get('type',true);			$so = $this->input->get('so',true);			$timetk = strtotime($timetk);			$timetj = strtotime($timetj);			$where = (isset($_SESSION['api']))?"library!=3 and libraryconfirm=2 and print = 3 and (".rtrim($wtype,'or').")":"id = '0'";			if($timetk && $timetj && $library == 1)            {				//$cxtime = 'reviewtime';                $where  .= "  and printtime > '$timetk - 180*24*3600' and printtime < '$timetj'";				$where  .= " and state != 217";				            }			else if($timetk && $timetj && $library == 2)            {				$cxtime = 'librarytime';                $where  .= " and librarytime > '$timetk' and librarytime < '$timetj'";            }			/**			$where = "library!=3 and libraryconfirm=2 and mergeid = 0 and print = 3";			if($timetk && $timetj && $library == 1)            {				//$cxtime = 'reviewtime';                //$where  .= " and librarytime > '$timetk' and librarytime < '$timetj'";            }			else if($timetk && $timetj && $library == 2)            {				$cxtime = 'librarytime';                $where  .= " and librarytime > '$timetk' and librarytime < '$timetj'";            }			**/			if(isset($_SESSION['api']))            {				if($type)            	{                	$where  .= " and type = '$type'";           		}				else				{					$uw = '';				    $u = $this->user->get_api($_SESSION['api']);				    $u['warehouse'] =  explode('|',trim($u['warehouse'],'|'));				    foreach ($u['warehouse'] as $v) 		            {					    $uw  .= " type = '$v' or";                    }				    $uw = rtrim($uw,'or');					$uw = " and (".ltrim($uw,' ').")";					$where  .= $uw;				}            }			else			{				echo json_encode(array('msg'=>'导出失败,请重新登陆!','success'=>false));exit;			}			if($shop)            {                $where  .= " and shop = '$shop'";            }			if($number)            {                $where  .= " and number = '$number'";            }			if($library)            {                $where  .= " and library = '$library'";            }			if($waybill)            {                $where  .= " and waybill = '$waybill'";            }			if($express)            {				$where  .= " and express = '$express'";            }			if($orderinfo)            {                $where  .= " and orderinfo = '$orderinfo'";            }			if($so)            {                $where  .= " and shipremarks like '%$so%'";            }            //数据排序			//$order_str = ($print != 3)?"id desc":"librarytime desc";			$order_str = "librarytime desc";            if(empty($page))		    {                $start = 0;		    	$perpage = 1;            }		    else		    {                $start = ($page - 1)*$perpage;            }			$typeclass = array();			$tclass = $this->typeclass->find_all();			foreach ($tclass as $v) 			{				$typeclass[$v['id']] = $v;			}            //取得信息列表            $info_list = $this->fullorder->find_all($where.$wid,'shop,type,orderinfo,number,waybill,express,print,library,librarytime,shipremarks,ts,fpdata',$order_str);			 //格式化数据            foreach ($info_list as $key=>$value) 		    {				$shop = $this->shop->read($value['shop']);				$info_list[$key]['shop'] = $shop['shopname'];				if($value['waybill'] == '0')				{					$info_list[$key]['waybill'] = "";				}				$express = $this->express->read($value['express']);				$info_list[$key]['express'] = $express['servicename'];				$warehouse = $this->warehouse->read($value['type']);				$info_list[$key]['type'] = $warehouse['title'];				if($value['print'] == 1)				{					$info_list[$key]['print'] = '不可打印';				}				else if($value['print'] == 2)				{					$info_list[$key]['print'] = '未打印';				}				else if($value['print'] == 3)				{					$info_list[$key]['print'] = '已打印';				}				if($value['library'] == 1)				{					$info_list[$key]['library'] = '<em class="c">未出库</em>';				}				else if($value['library'] == 2)				{					$info_list[$key]['library'] = '<em class="c">已出库</em>';				}				else if($value['library'] == 3)				{					$info_list[$key]['library'] = '<em class="c">已退库</em>';				}				if($value['librarytime'] == '0')				{					$info_list[$key]['librarytime'] = '<em class="t"></em>';				}				else				{					$info_list[$key]['librarytime'] = '<em class="t">'.date('Y-m-d H:i:s',$value['librarytime']).'</em>';				}								$classid = $classid = $this->classid->sku();				$dbapi = explode(';',trim($value['fpdata'],';'));					foreach ($dbapi as $va) 					{						$pm = $classid;		    			$jm = $classid;						$bmpx = array(13=>'',16=>'',18=>'',25=>'',26=>'',41=>'');						$features = str_replace(array('-163-','-164-','-165-','-166-'),'-',$va);						$ts = explode('|',trim($features,'|'));						if(stripos($ts[0],',') !== false)						{							$ft = explode(',',$ts[0]);			    			$features = explode('-',trim($ft[1],'-'));							$features[] = $ft[0];						}						else						{							$features = explode('-',trim($ts[0],'-'));						}						foreach($features as $k=>$v)						{							if(isset($typeclass[$v]) && isset($bmpx[$typeclass[$v]['classid']]))							{								if($typeclass[$v]['bm'] != '')								{									$bmpx[$typeclass[$v]['classid']] = $typeclass[$v]['bm'];								}							}							if($v != 0 && isset($typeclass[$v]))							{								if($typeclass[$v]['classid'] == 13)								{									$dj = $typeclass[$v]['title'];								}								if($typeclass[$v]['classid'] == 8)								{									$ys = $typeclass[$v]['title'];								}								if($typeclass[$v]['classid'] == 15)								{									$hx = $typeclass[$v]['title'];								}								if(isset($pm[$typeclass[$v]['classid']]))								{									if($typeclass[$v]['title'] == '9A')									{										$pm[$typeclass[$v]['classid']] = '9A';									}									else if($typeclass[$v]['title'] == '10A')									{										$pm[$typeclass[$v]['classid']] = '10A';									}									else									{										$clzh = $typeclass[$v]['zh'];										if(stripos($typeclass[$v]['zh'],'|') !== false)										{											$clzh = explode('|',rtrim($typeclass[$v]['zh'],'|'));											$clzh = $clzh[0];										}										$pm[$typeclass[$v]['classid']] = $clzh;									}								}								if(isset($jm[$typeclass[$v]['classid']]))								{									if($typeclass[$v]['jm'])									{						    			$jm[$typeclass[$v]['classid']] = $typeclass[$v]['jm'];									}								}							}						}						$jm = array_filter($jm);//去除空值						$jm = implode("-",$jm);						$pm = array_filter($pm);//去除空值						$zh = implode(" ",$pm);						$zh = preg_replace("/\r\n|\r|\n/",'',trim($zh,' '));					}					$info_list[$key]['jm'] = $jm;					$info_list[$key]['zh'] = $zh;            }			//取得信息列表            $info_listsmt = $this->fullordersmt->find_all($where.$wid,'shop,type,orderinfo,number,waybill,express,print,library,librarytime,shipremarks,ts,fpdata',$order_str);			 //格式化数据            foreach ($info_listsmt as $key=>$value) 		    {				$shop = $this->shop->read($value['shop']);				$info_listsmt[$key]['shop'] = $shop['shopname'];				if($value['waybill'] == '0')				{					$info_listsmt[$key]['waybill'] = "";				}				$express = $this->express->read($value['express']);				$info_listsmt[$key]['express'] = $express['servicename'];				$warehouse = $this->warehouse->read($value['type']);				$info_listsmt[$key]['type'] = $warehouse['title'];				if($value['print'] == 1)				{					$info_listsmt[$key]['print'] = '不可打印';				}				else if($value['print'] == 2)				{					$info_listsmt[$key]['print'] = '未打印';				}				else if($value['print'] == 3)				{					$info_listsmt[$key]['print'] = '已打印';				}				if($value['library'] == 1)				{					$info_listsmt[$key]['library'] = '<em class="c">未出库</em>';				}				else if($value['library'] == 2)				{					$info_listsmt[$key]['library'] = '<em class="c">已出库</em>';				}				else if($value['library'] == 3)				{					$info_listsmt[$key]['library'] = '<em class="c">已退库</em>';				}				if($value['librarytime'] == '0')				{					$info_listsmt[$key]['librarytime'] = '<em class="t"></em>';				}				else				{					$info_listsmt[$key]['librarytime'] = '<em class="t">'.date('Y-m-d H:i:s',$value['librarytime']).'</em>';				}				$classid = $classid = $this->classid->sku();				$dbapi = explode(';',trim($value['fpdata'],';'));					foreach ($dbapi as $va) 					{						$pm = $classid;		    			$jm = $classid;						$bmpx = array(13=>'',16=>'',18=>'',25=>'',26=>'',41=>'');						$features = str_replace(array('-163-','-164-','-165-','-166-'),'-',$va);						$ts = explode('|',trim($features,'|'));						if(stripos($ts[0],',') !== false)						{							$ft = explode(',',$ts[0]);			    			$features = explode('-',trim($ft[1],'-'));							$features[] = $ft[0];						}						else						{							$features = explode('-',trim($ts[0],'-'));						}						foreach($features as $k=>$v)						{							if(isset($typeclass[$v]) && isset($bmpx[$typeclass[$v]['classid']]))							{								if($typeclass[$v]['bm'] != '')								{									$bmpx[$typeclass[$v]['classid']] = $typeclass[$v]['bm'];								}							}							if($v != 0 && isset($typeclass[$v]))							{								if($typeclass[$v]['classid'] == 13)								{									$dj = $typeclass[$v]['title'];								}								if($typeclass[$v]['classid'] == 8)								{									$ys = $typeclass[$v]['title'];								}								if($typeclass[$v]['classid'] == 15)								{									$hx = $typeclass[$v]['title'];								}								if(isset($pm[$typeclass[$v]['classid']]))								{									if($typeclass[$v]['title'] == '9A')									{										$pm[$typeclass[$v]['classid']] = '9A';									}									else if($typeclass[$v]['title'] == '10A')									{										$pm[$typeclass[$v]['classid']] = '10A';									}									else									{										$clzh = $typeclass[$v]['zh'];										if(stripos($typeclass[$v]['zh'],'|') !== false)										{											$clzh = explode('|',rtrim($typeclass[$v]['zh'],'|'));											$clzh = $clzh[0];										}										$pm[$typeclass[$v]['classid']] = $clzh;									}								}								if(isset($jm[$typeclass[$v]['classid']]))								{									if($typeclass[$v]['jm'])									{						    			$jm[$typeclass[$v]['classid']] = $typeclass[$v]['jm'];									}								}							}						}						$jm = array_filter($jm);//去除空值						$jm = implode("-",$jm);						$pm = array_filter($pm);//去除空值						$zh = implode(" ",$pm);						$zh = preg_replace("/\r\n|\r|\n/",'',trim($zh,' '));					}					$info_listsmt[$key]['jm'] = $jm;					$info_listsmt[$key]['zh'] = $zh;            }			 //取得信息列表            $info_listtt = $this->fullordertt->find_all($where.$wid,'shop,type,orderinfo,number,waybill,express,print,library,librarytime,shipremarks,ts,fpdata',$order_str);			 //格式化数据            foreach ($info_listtt as $key=>$value) 		    {				$shop = $this->shop->read($value['shop']);				$info_listtt[$key]['shop'] = $shop['shopname'];				if($value['waybill'] == '0')				{					$info_listtt[$key]['waybill'] = "";				}				$express = $this->express->read($value['express']);				$info_listtt[$key]['express'] = $express['servicename'];				$warehouse = $this->warehouse->read($value['type']);				$info_listtt[$key]['type'] = $warehouse['title'];				if($value['print'] == 1)				{					$info_listtt[$key]['print'] = '不可打印';				}				else if($value['print'] == 2)				{					$info_listtt[$key]['print'] = '未打印';				}				else if($value['print'] == 3)				{					$info_listtt[$key]['print'] = '已打印';				}				if($value['library'] == 1)				{					$info_listtt[$key]['library'] = '<em class="c">未出库</em>';				}				else if($value['library'] == 2)				{					$info_listtt[$key]['library'] = '<em class="c">已出库</em>';				}				else if($value['library'] == 3)				{					$info_listtt[$key]['library'] = '<em class="c">已退库</em>';				}				if($value['librarytime'] == '0')				{					$info_listtt[$key]['librarytime'] = '<em class="t"></em>';				}				else				{					$info_listtt[$key]['librarytime'] = '<em class="t">'.date('Y-m-d H:i:s',$value['librarytime']).'</em>';				}				$classid = $classid = $this->classid->sku();				$dbapi = explode(';',trim($value['fpdata'],';'));					foreach ($dbapi as $va) 					{						$pm = $classid;		    			$jm = $classid;						$bmpx = array(13=>'',16=>'',18=>'',25=>'',26=>'',41=>'');						$features = str_replace(array('-163-','-164-','-165-','-166-'),'-',$va);						$ts = explode('|',trim($features,'|'));						if(stripos($ts[0],',') !== false)						{							$ft = explode(',',$ts[0]);			    			$features = explode('-',trim($ft[1],'-'));							$features[] = $ft[0];						}						else						{							$features = explode('-',trim($ts[0],'-'));						}						foreach($features as $k=>$v)						{							if(isset($typeclass[$v]) && isset($bmpx[$typeclass[$v]['classid']]))							{								if($typeclass[$v]['bm'] != '')								{									$bmpx[$typeclass[$v]['classid']] = $typeclass[$v]['bm'];								}							}							if($v != 0 && isset($typeclass[$v]))							{								if($typeclass[$v]['classid'] == 13)								{									$dj = $typeclass[$v]['title'];								}								if($typeclass[$v]['classid'] == 8)								{									$ys = $typeclass[$v]['title'];								}								if($typeclass[$v]['classid'] == 15)								{									$hx = $typeclass[$v]['title'];								}								if(isset($pm[$typeclass[$v]['classid']]))								{									if($typeclass[$v]['title'] == '9A')									{										$pm[$typeclass[$v]['classid']] = '9A';									}									else if($typeclass[$v]['title'] == '10A')									{										$pm[$typeclass[$v]['classid']] = '10A';									}									else									{										$clzh = $typeclass[$v]['zh'];										if(stripos($typeclass[$v]['zh'],'|') !== false)										{											$clzh = explode('|',rtrim($typeclass[$v]['zh'],'|'));											$clzh = $clzh[0];										}										$pm[$typeclass[$v]['classid']] = $clzh;									}								}								if(isset($jm[$typeclass[$v]['classid']]))								{									if($typeclass[$v]['jm'])									{						    			$jm[$typeclass[$v]['classid']] = $typeclass[$v]['jm'];									}								}							}						}						$jm = array_filter($jm);//去除空值						$jm = implode("-",$jm);						$pm = array_filter($pm);//去除空值						$zh = implode(" ",$pm);						$zh = preg_replace("/\r\n|\r|\n/",'',trim($zh,' '));					}					$info_listtt[$key]['jm'] = $jm;					$info_listtt[$key]['zh'] = $zh;            }									 //取得信息列表            $info_listxw = $this->fullorderxw->find_all($where.$wid,'shop,type,orderinfo,number,waybill,express,print,library,librarytime,shipremarks,ts,fpdata',$order_str);			 //格式化数据            foreach ($info_listxw as $key=>$value) 		    {				$shop = $this->shop->read($value['shop']);				$info_listxw[$key]['shop'] = $shop['shopname'];				if($value['waybill'] == '0')				{					$info_listxw[$key]['waybill'] = "";				}				$express = $this->express->read($value['express']);				$info_listxw[$key]['express'] = $express['servicename'];				$warehouse = $this->warehouse->read($value['type']);				$info_listxw[$key]['type'] = $warehouse['title'];				if($value['print'] == 1)				{					$info_listxw[$key]['print'] = '不可打印';				}				else if($value['print'] == 2)				{					$info_listxw[$key]['print'] = '未打印';				}				else if($value['print'] == 3)				{					$info_listxw[$key]['print'] = '已打印';				}				if($value['library'] == 1)				{					$info_listxw[$key]['library'] = '<em class="c">未出库</em>';				}				else if($value['library'] == 2)				{					$info_listxw[$key]['library'] = '<em class="c">已出库</em>';				}				else if($value['library'] == 3)				{					$info_listxw[$key]['library'] = '<em class="c">已退库</em>';				}				if($value['librarytime'] == '0')				{					$info_listxw[$key]['librarytime'] = '<em class="t"></em>';				}				else				{					$info_listxw[$key]['librarytime'] = '<em class="t">'.date('Y-m-d H:i:s',$value['librarytime']).'</em>';				}				$classid = $classid = $this->classid->sku();				$dbapi = explode(';',trim($value['fpdata'],';'));					foreach ($dbapi as $va) 					{						$pm = $classid;		    			$jm = $classid;						$bmpx = array(13=>'',16=>'',18=>'',25=>'',26=>'',41=>'');						$features = str_replace(array('-163-','-164-','-165-','-166-'),'-',$va);						$ts = explode('|',trim($features,'|'));						if(stripos($ts[0],',') !== false)						{							$ft = explode(',',$ts[0]);			    			$features = explode('-',trim($ft[1],'-'));							$features[] = $ft[0];						}						else						{							$features = explode('-',trim($ts[0],'-'));						}						foreach($features as $k=>$v)						{							if(isset($typeclass[$v]) && isset($bmpx[$typeclass[$v]['classid']]))							{								if($typeclass[$v]['bm'] != '')								{									$bmpx[$typeclass[$v]['classid']] = $typeclass[$v]['bm'];								}							}							if($v != 0 && isset($typeclass[$v]))							{								if($typeclass[$v]['classid'] == 13)								{									$dj = $typeclass[$v]['title'];								}								if($typeclass[$v]['classid'] == 8)								{									$ys = $typeclass[$v]['title'];								}								if($typeclass[$v]['classid'] == 15)								{									$hx = $typeclass[$v]['title'];								}								if(isset($pm[$typeclass[$v]['classid']]))								{									if($typeclass[$v]['title'] == '9A')									{										$pm[$typeclass[$v]['classid']] = '9A';									}									else if($typeclass[$v]['title'] == '10A')									{										$pm[$typeclass[$v]['classid']] = '10A';									}									else									{										$clzh = $typeclass[$v]['zh'];										if(stripos($typeclass[$v]['zh'],'|') !== false)										{											$clzh = explode('|',rtrim($typeclass[$v]['zh'],'|'));											$clzh = $clzh[0];										}										$pm[$typeclass[$v]['classid']] = $clzh;									}								}								if(isset($jm[$typeclass[$v]['classid']]))								{									if($typeclass[$v]['jm'])									{						    			$jm[$typeclass[$v]['classid']] = $typeclass[$v]['jm'];									}								}							}						}						$jm = array_filter($jm);//去除空值						$jm = implode("-",$jm);						$pm = array_filter($pm);//去除空值						$zh = implode(" ",$pm);						$zh = preg_replace("/\r\n|\r|\n/",'',trim($zh,' '));					}					$info_listxw[$key]['jm'] = $jm;					$info_listxw[$key]['zh'] = $zh;            }            $title = '订单出库-'.date('Ymd',time());            $titlename = "<table border=1>".$t."<td>条数</td><td>料品</td><td>品名</td></table>";			$tail = "\n";            $filename = $title.".xls";            $this->excel->get_fz2(array_merge($info_list,$info_listtt,$info_listxw,$info_listsmt),$titlename,$filename,$tail);		}	}		public function _cpexcel()	{		if(isset($_SESSION['api']))		{			$user = $this->user->get_api($_SESSION['api']);			$usp = $user;		    $fgshop = "";$sid = "";$excelshop="";		    $usersp = explode('|',trim($user['shop'],'|'));			foreach ($usersp as $value) 		    {				$fgshop .= " shop = ".$value." or";				$sid .= " id = ".$value." or";			}			$userexcel = explode('|',trim($user['excelshop'],'|'));			foreach ($userexcel as $value) 		    {				$excelshop .= " shop =  ".$value." or";			}			if($excelshop != "")			{				$excelshop = "(".rtrim($excelshop,'or').")";			}		}		if(isset($_GET['excel']))  		{			$timetk = $this->input->get('timetk',true);			$timetj = $this->input->get('timetj',true);			$shop = $this->input->get('shop',true);			$library = $this->input->get('library',true);			$type = $this->input->get('type',true);			$number = $this->input->get('number',true);			$orderinfo = $this->input->get('orderinfo',true);			$so = $this->input->get('so',true);			$number = $this->input->get('number',true);			$express = $this->input->get('express',true);			$timetk = strtotime($timetk);			$timetj = strtotime($timetj);			$where = "mergeid = 0";			if($timetk && $timetj && $library == 2)            {                $where  .= " and librarytime > '$timetk' and librarytime < '$timetj'";            }			else			{				$where  .= " and printtime > '$timetk' and printtime < '$timetj'";			}			if(isset($_SESSION['api']))            {				if($type)            	{                	$where  .= " and type = '$type'";           		}				else				{					$uw = '';				    $u = $this->user->get_api($_SESSION['api']);				    $u['warehouse'] =  explode('|',trim($u['warehouse'],'|'));				    foreach ($u['warehouse'] as $v) 		            {					    $uw  .= " type = '$v' or";                    }				    $uw = rtrim($uw,'or');					$uw = " and (".ltrim($uw,' ').")";					$where  .= $uw;				}            }			else			{				echo json_encode(array('msg'=>'导出失败,请重新登陆!','success'=>false));exit;			}			if($shop)            {                $where  .= " and shop = '$shop'";            }			else			{				$where  .= " and ".$excelshop;			}			if($library)            {				$where  .= " and library = '$library'";            }			if($number)            {                $where  .= " and number = '$number'";            }			if($orderinfo)            {                $where  .= " and orderinfo = '$orderinfo'";            }			if($so)            {                $where  .= " and shipremarks like '%$so%'";            }			if($express)            {                $where  .= " and express = '$express'";            }			/*  匹配ID加入  */			$tc = array();			$typeclass = $this->typeclass->find_all();			foreach ($typeclass as $v) 			{				$tc[$v['id']] = $v['title'];			}			$shouldmoney=0;$expressmoney=0;$budget=0;$refundj=0;$refundj=0;$cost=0;$lr=0;            //取得信息列表			$info_lista = $this->fullordersmt->find_all($where,'fpdata');			$info_listb = $this->fullorder->find_all($where,'fpdata');			$info_list = array_merge($info_lista,$info_listb);			 //格式化数据			$i = 0;$cpexcel = array();			foreach ($info_list as $key=>$value)		    {				if(stripos($value['fpdata'],';') !== false)				{		   		    $fpdata = explode(';',rtrim($value['fpdata'],';'));		            foreach ($fpdata as $ke=>$va)		            {						$title = '';			            $fg = explode('|',$va);						$fg[0] = str_replace(array('163-','164-','165-','166-','-0-'),array('','','','','-'),$fg[0]);						$cp = explode('-',rtrim($fg[0],'-'));						$dj = $tc[$cp[2]];						if(!isset($cp[3]))						{							$ys = json_encode($cp);						}						else						{						    $ys = $tc[$cp[3]];						}						unset($cp[0],$cp[1],$cp[2],$cp[3]);						foreach ($cp as $v)		                {							$title .= $tc[$v].' ';						}						$cpexcel[$ke] = array($fg[5],$dj,$ys,$title,$fg[2]);//内容,尺寸,等级,颜色,数量                    }				}				$i++;            }            $title = "统计信息";             $titlename = "<table border=1>            <tr>            <td>尺寸</td>			<td>等级</td>			<td>颜色</td>			<td>花型</td>			<td>数量</td>            </tr>            </table>";             $filename = $title.".xls"; 			$tail = "\n";             $this->excel->get_fz2($cpexcel,$titlename,$filename,$tail);	    }	}	public function _orderyz()	{		$post = $this->input->post(NULL, TRUE);		if(isset($post['yz']))		{			$yz = $this->input->post('yz',true);			$number = $this->input->post('number',true);			$y  = $this->fullorder->get_number($number);			if(!$y)			{				$y  = $this->fullordersmt->get_number($number);				if(!$y)			    {					echo json_encode(array('msg'=>'没有找到此订单,请检查是否扫描错误','success'=>false));exit;				}			}			$whlabel = explode('|',trim($y['whlabel'],'|'));			foreach($whlabel as $k=>$v)			{				$w = explode('-',trim($v,'-'));				$wldata[$w[0]] = $w;			}			$whlabellabel = $this->whlabellabel->get_label($yz);			if(!$whlabellabel)			{				echo json_encode(array('msg'=>'没有找到此产品条码','success'=>false));exit;			}			else			{				if(isset($wldata[$whlabellabel['number']]))				{					if(!isset($wldata[$whlabellabel['number']][2]))					{						echo json_encode(array('msg'=>'此货物没有占单!','success'=>false));exit;					}					else if($wldata[$whlabellabel['number']][2] == 0)					{						echo json_encode(array('msg'=>'此货物没有占单!','success'=>false));exit;					}				}				else				{					echo json_encode(array('msg'=>'此订单中没有扫码产品!','success'=>false));exit;				}					echo json_encode(array('number'=>$whlabellabel['number'],'success'=>true));exit;							}		}		if(isset($post['number']))  		{			$number = $this->input->post('number',true);			$f = 'fullorder';			$y  = $this->fullorder->get_number($number);			if(!$y)			{				$f = 'fullordersmt';				$y  = $this->fullordersmt->get_number($number);				if(!$y)			    {					echo json_encode(array('msg'=>'没有找到此订单,请检查是否扫描错误','success'=>false));exit;				}			}			if($y['librarytime'] > 0)			{				echo json_encode(array('msg'=>'错误,此订单已出库!','success'=>false));exit;			}			$warehouse = $this->warehouse->read($y['type']);			if(stripos($y['whlabel'],$warehouse['hz']) === false)			{				echo json_encode(array('msg'=>'pz','success'=>false));exit;			}			$data = explode('|',trim($y['whlabel'],'|'));			$fpdata = explode(';',trim($y['fpdata'],';'));			$cp = array();$i = 0;$x=0;$byz = array();$znum = 0;			foreach($fpdata as $val)			{				$pm = array(13=>'',22=>'',8=>'',15=>'',18=>'','100'=>'',33=>'',34=>'',7=>'','dc'=>'','c'=>'',14=>'',12=>'',25=>'',26=>'',27=>'',10=>'',6=>'',9=>'',999=>'',9999=>'');				$scsku = array(13=>'',22=>'',8=>'',15=>'',18=>'','100'=>'',33=>'',34=>'',7=>'','dc'=>'','c'=>'',14=>'',12=>'',25=>'',26=>'',27=>'',10=>'',6=>'',9=>'',999=>'',9999=>'');				$fp = explode('|',$val);				$fp[0] = str_replace(',','-',$fp[0]);				$value = explode('-',$fp[0]);				foreach($value as $v)				{					$typeclass = $this->typeclass->read($v);					$zh = explode('|',trim($typeclass['zh'],'|'));					$pm[$typeclass['classid']] = $zh[0];					$scsku[$typeclass['classid']] = $typeclass['bqsku'];				}				$scsku = implode("-",$scsku);				$zh = implode(" ",$pm);				$zh = str_replace('自然色 ','',rtrim($zh,' '));				$scsku = str_replace('- ','-',trim($scsku,'-'));				$scsku = str_replace(array('--------','-------','------','-----','----','---','--'),'-',$scsku);				$zh = str_replace(array('        ','       ','      ','     ','    ','   ','  '),' ',$zh);				$data[$i] = explode('-',$data[$i]);				for($j=0;$j<$data[$i][1];$j++)				{				    if(isset($data[$i][2]) && $warehouse['hz'] != '' && stripos($data[$i][2],$warehouse['hz']) !== false)				    {						$znum++;//只计算现货					    //$cp[$x] = array('id'=>$data[$i][0],'sku'=>$scsku,'zh'=>$zh,'t'=>'<span data-id="'.$data[$i][0].'">替换现货</sapn>','c'=>1,'color'=>'#333');//区别位置模式,暂不使用						$cp[] = array('id'=>$data[$i][0],'sku'=>$scsku,'zh'=>$zh,'y'=>'已占单','t'=>'<span data-id="'.$data[$i][0].'">替换现货</sapn>','c'=>1,'color'=>'#333');					}					else					{						//$cp[999+$x] = array('id'=>$data[$i][0],'sku'=>$scsku,'zh'=>$zh,'t'=>'<span data-id="'.$data[$i][0].'" style="background-color:#ccc">增加现货</sapn>','c'=>0,'color'=>'#999');//区别位置模式,暂不使用						$cp[] = array('id'=>$data[$i][0],'sku'=>$scsku,'zh'=>$zh,'y'=>'','t'=>'<span data-id="'.$data[$i][0].'" style="background-color:#e7ba08">增加现货</sapn>','c'=>0,'color'=>'#666');				    }					$x++;//所有数量				}				$i++;            }			//ksort($cp);//区别位置模式,暂不使用			$cp = array_values($cp);			if($this->$f->save(array('yhs'=>1),$y['id']))			{			    echo json_encode(array('rows'=>$cp,'z'=>$znum,'success'=>true));exit;			}			else			{				echo json_encode(array('msg'=>'处理信息失败,请重试','success'=>false));exit;			}		}		if(isset($post['tid']))  		{			$typeclass = array();			$tc = $this->typeclass->find_all();			foreach($tc as $v)			{				$typeclass[$v['id']] = array('id'=>$v['id'],'classid'=>$v['classid'],'spare'=>$v['spare']);			}			$tid = $this->input->post('tid',true);			$id = $this->input->post('id',true);			$number = $this->input->post('n',true);			$ful = 'fullorder';			$y  = $this->fullorder->get_number($number);			if(!$y)			{				$ful = 'fullordersmt';				$y  = $this->fullordersmt->get_number($number);				if(!$y)			    {					echo json_encode(array('msg'=>'没有找到此订单,请检查是否扫描错误','success'=>false));exit;				}			}			$wtid = $this->whlabellabel->get_label($tid);			if(!$wtid)			{				echo json_encode(array('msg'=>'没有找到此产品条码','success'=>false));exit;			}			$whlabel = explode('|',trim($y['whlabel'],'|'));			$fpdata = explode(';',trim($y['fpdata'],';'));			$warehouse = $this->warehouse->read($y['type']);			$zdkc = $warehouse['bdck'];			$ptc = $this->$zdkc->find_all("state = '0' and number = '".$wtid['number']."' and warehouse = '".$warehouse['id']."' and zd = '' and (shop IS NULL or shop = '')");//通用			$zsc = $this->$zdkc->find_all("state = '0' and number = '".$wtid['number']."' and warehouse = '".$warehouse['id']."' and zd = '' and shop like '%,".$y['shop'].",%'");//专属			if((count($ptc)+count($zsc)) < 1)			{				echo json_encode(array('msg'=>'录入的产品没有足够的库存!-'.(count($ptc)+count($zsc)),'success'=>false));exit;			}			$this->db->trans_begin();			$dataw = '';$dataf = '';$fhdata = array();$ww = '';$ff = '';$thff = '';			if($zsc)			{				$this->$zdkc->save(array('zd'=>$number),$zsc[0]['id']);				$xrid = $zsc[0]['id'];			}			else if($ptc)			{				$this->$zdkc->save(array('zd'=>$number),$ptc[0]['id']);				$xrid = $ptc[0]['id'];		    }			$xr = $this->$zdkc->read($xrid);			$features = explode('-',trim($xr['features'],'-'));			$fhdata = array('sku'=>$xr['sku'],'title'=>$xr['title'],'id'=>$xr['features']);			foreach($features as $kk=>$v)			{				if($typeclass[$v]['classid'] == 14)				{					$cc = array('id'=>$typeclass[$v]['id'],'spare'=>$typeclass[$v]['spare']);					unset($kk);				}			}			$dataw = $tid.'-1-'.$xrid.$warehouse['hz'].'|';			$dataf = $cc['id'].',-'.implode("-",$features).'-|'.$xr['title'].' |1|0|0|'.$cc['spare'].'|0|0|0|'.$xr['id'].$warehouse['hz'].';';			$wldata = array();			$fdata = array();			foreach($whlabel as $k=>$v)			{				$w = explode('-',trim($v,'-'));				$wldata[$w[0]] = array('wz'=>$k,'sj'=>$w);			}			if(!isset($wldata[$id]))			{				echo json_encode(array('msg'=>'错误,未找到需要替换的产品,请重新扫发货单条码验货','success'=>false));exit;			}			if(isset($wldata[$wtid['number']]['sj']))			{				$tw = $wldata[$wtid['number']]['sj'];				if($wtid['number'] != $id)				{				    echo json_encode(array('msg'=>'替换的产品已存在,请操作此产品','success'=>false));exit;				}				else				{					if(isset($tw[2]) && $tw[2] != 0)					{						echo json_encode(array('msg'=>'替换的产品已存在,并且已占单,无法操作替换!','success'=>false));exit;					}				}				if($tw[1] > 1)				{					echo json_encode(array('msg'=>'替换的产品已存在,并且已数量为大于1,无法操作替换!','success'=>false));exit;				}							}			$thfpdata = $y['thfpdata'];			$w = $wldata[$id]['sj'];			$f = explode('|',trim($fpdata[$wldata[$id]['wz']],'|'));			$zdkc = $warehouse['bdck'];			if($w[1] > 1)			{				if(isset($w[2]) && $w[2] != 0)				{					$hz = explode('~',trim($w[2],'~'));					$this->$zdkc->save(array('zd'=>''),trim($hz[0],$warehouse['hz']));					$zd = str_replace($hz[0],'',$w[2]);					$zd = trim($zd,'~');					$w[2] = $zd;				}				foreach($w as $kk=>$v)				{					if($kk == 1)					{						$v = $v-1;					}					$ww .= $v .'-';				}				$whlabel[$wldata[$id]['wz']] = trim($ww,'-');				foreach($f as $kk=>$v)				{					if($kk == 2)					{						$v = $v-1;						$thff .= '1|';					}					else					{						$thff .= $v .'|';					}					$ff .= $v .'|';				}				$fpdata[$wldata[$id]['wz']] = trim($ff,'|');				$thfpdata .= trim($thff,'|');			}			else			{				$thfpdata .= $fpdata[$wldata[$id]['wz']];				unset($whlabel[$wldata[$id]['wz']]);				unset($fpdata[$wldata[$id]['wz']]);			}			$thfpdata .= '~'.$dataf;			$whlabel = '|'.implode("|",$whlabel).'|'.$dataw;			$fpdata = implode(";",$fpdata).';'.$dataf;			$this->$ful->save(array('whlabel'=>$whlabel,'fpdata'=>$fpdata,'thfpdata'=>$thfpdata),$y['id']);			if ($this->db->trans_status() === TRUE)        	{				$this->db->trans_commit();				echo json_encode(array('sku'=>$fhdata['sku'],'title'=>$fhdata['title'],'id'=>$fhdata['id'],'msg'=>321,'success'=>true));exit;			}			else			{				$this->db->trans_rollback();				echo json_encode(array('msg'=>'条码录入失败,请重试','success'=>false));exit;			}		}		if(isset($post['yhs']))  		{			$f = 'fullorder';			$number = $this->input->post('yhs',true);			$y  = $this->fullorder->get_number($number);			if(!$y)			{				$f = 'fullordersmt';				$y  = $this->fullordersmt->get_number($number);			}			if($this->$f->save(array('yhs'=>0),$y['id']))			{				echo json_encode(array('success'=>true));exit;			}			else			{				echo json_encode(array('success'=>false));exit;			}		}		$this->_Template('systemfout_orderyz',$this->data);	}				public function _hwyz()	{		$post = $this->input->post(NULL, TRUE);		if(isset($post['yz']))  		{			$yz = $this->input->post('yz',true);			$number = $this->input->post('number',true);			$y  = $this->fullorder->get_number($number);			if(!$y)			{				$y  = $this->fullordersmt->get_number($number);				if(!$y)			    {					echo json_encode(array('msg'=>'没有找到此订单,请检查是否扫描错误','success'=>false));exit;				}			}			$whlabel = explode('|',trim($y['whlabel'],'|'));			foreach($whlabel as $k=>$v)			{				$w = explode('-',trim($v,'-'));				$wldata[$w[0]] = $w;			}			$whlabellabel = $this->whlabellabel->get_label($yz);			if(!$whlabellabel)			{				echo json_encode(array('msg'=>'没有找到此产品条码','success'=>false));exit;			}			else			{				if(isset($wldata[$whlabellabel['number']]))				{					if(!isset($wldata[$whlabellabel['number']][2]))					{						echo json_encode(array('msg'=>'此货物没有占单!','success'=>false));exit;					}					else if($wldata[$whlabellabel['number']][2] == 0)					{						echo json_encode(array('msg'=>'此货物没有占单!','success'=>false));exit;					}				}				else				{					echo json_encode(array('msg'=>'此订单中没有扫码产品!','success'=>false));exit;				}					echo json_encode(array('number'=>$whlabellabel['number'],'success'=>true));exit;							}		}		if(isset($post['number']))  		{			$number = $this->input->post('number',true);			$f = 'fullorder';			$y  = $this->fullorder->get_number($number);			if(!$y)			{				$f = 'fullordersmt';				$y  = $this->fullordersmt->get_number($number);				if(!$y)			    {					echo json_encode(array('msg'=>'没有找到此订单,请检查是否扫描错误','success'=>false));exit;				}			}			if($y['librarytime'] > 0)			{				echo json_encode(array('msg'=>'错误,此订单已出库!','success'=>false));exit;			}			$warehouse = $this->warehouse->read($y['type']);			$data = explode('|',trim($y['whlabel'],'|'));			$fpdata = explode(';',trim($y['fpdata'],';'));			$cp = array();$i = 0;$x=0;$byz = array();$znum = 0;			foreach($fpdata as $val)			{				$pm = array(13=>'',22=>'',8=>'',15=>'',18=>'','100'=>'',33=>'',34=>'',7=>'','dc'=>'','c'=>'',14=>'',12=>'',25=>'',26=>'',27=>'',10=>'',6=>'',9=>'',999=>'',9999=>'');				$scsku = array(13=>'',22=>'',8=>'',15=>'',18=>'','100'=>'',33=>'',34=>'',7=>'','dc'=>'','c'=>'',14=>'',12=>'',25=>'',26=>'',27=>'',10=>'',6=>'',9=>'',999=>'',9999=>'');				$fp = explode('|',$val);				$fp[0] = str_replace(',','-',$fp[0]);				$value = explode('-',$fp[0]);				foreach($value as $v)				{					$typeclass = $this->typeclass->read($v);					$zh = explode('|',trim($typeclass['zh'],'|'));					$pm[$typeclass['classid']] = $zh[0];					$scsku[$typeclass['classid']] = $typeclass['bqsku'];				}				$scsku = implode("-",$scsku);				$zh = implode(" ",$pm);				$zh = str_replace('自然色 ','',rtrim($zh,' '));				$scsku = str_replace('- ','-',trim($scsku,'-'));				$scsku = str_replace(array('--------','-------','------','-----','----','---','--'),'-',$scsku);				$zh = str_replace(array('        ','       ','      ','     ','    ','   ','  '),' ',$zh);				$data[$i] = explode('-',$data[$i]);				for($j=0;$j<$data[$i][1];$j++)				{				    if(isset($data[$i][2]) && $warehouse['hz'] != '' && stripos($data[$i][2],$warehouse['hz']) !== false)				    {						$znum++;//只计算现货					    //$cp[$x] = array('id'=>$data[$i][0],'sku'=>$scsku,'zh'=>$zh,'t'=>'<span data-id="'.$data[$i][0].'">替换现货</sapn>','c'=>1,'color'=>'#333');//区别位置模式,暂不使用						$cp[] = array('id'=>$data[$i][0],'sku'=>$scsku,'zh'=>$zh,'y'=>'已占单','t'=>'<span data-id="'.$data[$i][0].'">替换现货</sapn>','c'=>1,'color'=>'#333');					}					else					{						//$cp[999+$x] = array('id'=>$data[$i][0],'sku'=>$scsku,'zh'=>$zh,'t'=>'<span data-id="'.$data[$i][0].'" style="background-color:#ccc">增加现货</sapn>','c'=>0,'color'=>'#999');//区别位置模式,暂不使用						$cp[] = array('id'=>$data[$i][0],'sku'=>$scsku,'zh'=>$zh,'y'=>'','t'=>'<span data-id="'.$data[$i][0].'" style="background-color:#e7ba08">增加现货</sapn>','c'=>0,'color'=>'#666');				    }					$x++;//所有数量				}				$i++;            }			//ksort($cp);//区别位置模式,暂不使用			$cp = array_values($cp);			if($this->$f->save(array('yhs'=>1),$y['id']))			{				if(stripos($y['whlabel'],$warehouse['hz']) === false)				{					echo json_encode(array('rows'=>$cp,'z'=>$znum,'msg'=>'pz','success'=>false));exit;				}			    echo json_encode(array('rows'=>$cp,'z'=>$znum,'success'=>true));exit;			}			else			{				echo json_encode(array('msg'=>'处理信息失败,请重试','success'=>false));exit;			}		}		if(isset($post['tid']))  		{			$typeclass = array();			$tc = $this->typeclass->find_all();			foreach($tc as $v)			{				$typeclass[$v['id']] = array('id'=>$v['id'],'classid'=>$v['classid'],'spare'=>$v['spare']);			}			$tid = $this->input->post('tid',true);			$id = $this->input->post('id',true);			$number = $this->input->post('n',true);			$ful = 'fullorder';			$y  = $this->fullorder->get_number($number);			if(!$y)			{				$ful = 'fullordersmt';				$y  = $this->fullordersmt->get_number($number);				if(!$y)			    {					echo json_encode(array('msg'=>'没有找到此订单,请检查是否扫描错误','success'=>false));exit;				}			}			$wtid = $this->whlabellabel->get_label($tid);			if(!$wtid)			{				echo json_encode(array('msg'=>'没有找到此产品条码','success'=>false));exit;			}			$whlabel = explode('|',trim($y['whlabel'],'|'));			$fpdata = explode(';',trim($y['fpdata'],';'));			$warehouse = $this->warehouse->read($y['type']);			$zdkc = $warehouse['bdck'];			$ptc = $this->$zdkc->find_all("state = '0' and number = '".$wtid['number']."' and warehouse = '".$warehouse['id']."' and zd = '' and (shop IS NULL or shop = '')");//通用			$zsc = $this->$zdkc->find_all("state = '0' and number = '".$wtid['number']."' and warehouse = '".$warehouse['id']."' and zd = '' and shop like '%,".$y['shop'].",%'");//专属			if((count($ptc)+count($zsc)) < 1)			{				echo json_encode(array('msg'=>'录入的产品没有足够的库存!-'.(count($ptc)+count($zsc)),'success'=>false));exit;			}			$this->db->trans_begin();			$dataw = '';$dataf = '';$fhdata = array();$ww = '';$ff = '';$thff = '';			if($zsc)			{				$this->$zdkc->save(array('zd'=>$number),$zsc[0]['id']);				$xrid = $zsc[0]['id'];			}			else if($ptc)			{				$this->$zdkc->save(array('zd'=>$number),$ptc[0]['id']);				$xrid = $ptc[0]['id'];		    }			$xr = $this->$zdkc->read($xrid);			$features = explode('-',trim($xr['features'],'-'));			$fhdata = array('sku'=>$xr['sku'],'title'=>$xr['title'],'id'=>$xr['features']);			foreach($features as $kk=>$v)			{				if($typeclass[$v]['classid'] == 14)				{					$cc = array('id'=>$typeclass[$v]['id'],'spare'=>$typeclass[$v]['spare']);					unset($kk);				}			}			$dataw = $tid.'-1-'.$xrid.$warehouse['hz'].'|';			$dataf = $cc['id'].',-'.implode("-",$features).'-|'.$xr['title'].' |1|0|0|'.$cc['spare'].'|0|0|0|'.$xr['id'].$warehouse['hz'].';';			$wldata = array();			$fdata = array();			foreach($whlabel as $k=>$v)			{				$w = explode('-',trim($v,'-'));				$wldata[$w[0]] = array('wz'=>$k,'sj'=>$w);			}			if(!isset($wldata[$id]))			{				echo json_encode(array('msg'=>'错误,未找到需要替换的产品,请重新扫发货单条码验货','success'=>false));exit;			}			if(isset($wldata[$wtid['number']]['sj']))			{				$tw = $wldata[$wtid['number']]['sj'];				if($wtid['number'] != $id)				{				    echo json_encode(array('msg'=>'替换的产品已存在,请操作此产品','success'=>false));exit;				}				else				{					if(isset($tw[2]) && $tw[2] != 0)					{						echo json_encode(array('msg'=>'替换的产品已存在,并且已占单,无法操作替换!','success'=>false));exit;					}				}				if($tw[1] > 1)				{					echo json_encode(array('msg'=>'替换的产品已存在,并且已数量为大于1,无法操作替换!','success'=>false));exit;				}							}			$thfpdata = $y['thfpdata'];			$w = $wldata[$id]['sj'];			$f = explode('|',trim($fpdata[$wldata[$id]['wz']],'|'));			$zdkc = $warehouse['bdck'];			if($w[1] > 1)			{				if(isset($w[2]) && $w[2] != 0)				{					$hz = explode('~',trim($w[2],'~'));					$this->$zdkc->save(array('zd'=>''),trim($hz[0],$warehouse['hz']));					$zd = str_replace($hz[0],'',$w[2]);					$zd = trim($zd,'~');					$w[2] = $zd;				}				foreach($w as $kk=>$v)				{					if($kk == 1)					{						$v = $v-1;					}					$ww .= $v .'-';				}				$whlabel[$wldata[$id]['wz']] = trim($ww,'-');				foreach($f as $kk=>$v)				{					if($kk == 2)					{						$v = $v-1;						$thff .= '1|';					}					else					{						$thff .= $v .'|';					}					$ff .= $v .'|';				}				$fpdata[$wldata[$id]['wz']] = trim($ff,'|');				$thfpdata .= trim($thff,'|');			}			else			{				$thfpdata .= $fpdata[$wldata[$id]['wz']];				unset($whlabel[$wldata[$id]['wz']]);				unset($fpdata[$wldata[$id]['wz']]);			}			$thfpdata .= '~'.$dataf;			$whlabel = '|'.implode("|",$whlabel).'|'.$dataw;			$fpdata = implode(";",$fpdata).';'.$dataf;			$this->$ful->save(array('whlabel'=>$whlabel,'fpdata'=>$fpdata,'thfpdata'=>$thfpdata),$y['id']);			if ($this->db->trans_status() === TRUE)        	{				$this->db->trans_commit();				echo json_encode(array('sku'=>$fhdata['sku'],'title'=>$fhdata['title'],'id'=>$fhdata['id'],'msg'=>321,'success'=>true));exit;			}			else			{				$this->db->trans_rollback();				echo json_encode(array('msg'=>'条码录入失败,请重试','success'=>false));exit;			}		}		if(isset($post['yhs']))  		{			$f = 'fullorder';			$number = $this->input->post('yhs',true);			$y  = $this->fullorder->get_number($number);			if(!$y)			{				$f = 'fullordersmt';				$y  = $this->fullordersmt->get_number($number);			}			if($this->$f->save(array('yhs'=>0),$y['id']))			{				echo json_encode(array('success'=>true));exit;			}			else			{				echo json_encode(array('success'=>false));exit;			}		}		$this->_Template('systemfout_hwyz',$this->data);	}			public function _fouthb()	{		$post = $this->input->post(NULL, TRUE);		$xw = '';		if(isset($_SESSION['api']))		{			$user = $this->user->get_api($_SESSION['api']);			$usp = $user;		    $fgshop = "";$sid = "";$wid="";$wtype="";		    $usersp = explode('|',trim($user['shop'],'|'));			$userwh = explode('|',trim($user['warehouse'],'|'));			foreach ($usersp as $value) 		    {				$fgshop .= " shop = ".$value." or";				$sid .= " id = ".$value." or";			}			foreach ($userwh as $value) 		    {				$wid .= " id = ".$value." or";				$wtype .= " type = ".$value." or";			}			if($user['userid'] == 'xw')			{				$xw = 1;			}		}		if(isset($post['page']))  		{		    $page = $this->input->post('page',true);		    $perpage = $this->input->post('perpage',true);			$timetk = $this->input->post('timetk',true);			$timetj = $this->input->post('timetj',true);			$shop = $this->input->post('shop',true);			$type = $this->input->post('type',true);			$express = $this->input->post('express',true);			$number = $this->input->post('number',true);			$waybill = $this->input->post('waybill',true);			$librarytime = $this->input->post('librarytime',true);			$timetk = strtotime($timetk);			$timetj = strtotime($timetj);			$where = "mergeid = '1'";            $where  .= " and librarytime > '$timetk' and librarytime < '$timetj'";			if($shop)            {                $where  .= " and shop = '$shop'";            }			if($number)            {                $where  .= " and number like '$number%'";            }			if($waybill)            {                $where  .= " and waybill = '$waybill'";            }			if($type)            {                $where  .= " and type = '$type'";            }			if($express)            {				$where  .= " and express = '$express'";            }            //数据排序            $order_str = "librarytime desc";            if(empty($page))		    {                $start = 0;		    	$perpage = 1;            }		    else		    {                $start = ($page - 1)*$perpage;            }            //取得信息列表            $info_list = $this->fullorder->find_all($where,'id,shop,number,waybill,express,librarytime',$order_str,$start,$perpage);			 //格式化数据            foreach ($info_list as $key=>$value)		    {				$shop = $this->shop->read($value['shop']);				$info_list[$key]['shop'] = $shop['shopname'];				$express = $this->express->read($value['express']);				$info_list[$key]['express'] = $express['servicename'];				$warehouse = $this->warehouse->read($value['type']);				$info_list[$key]['type'] = $warehouse['title'];				$info_list[$key]['librarytime'] = '<em class="t">'.date('Y-m-d H:i',$value['librarytime']).'</em>';            }			$info_listtt = $this->fullordertt->find_all($where,'id,shop,type,orderinfo,number,waybill,express,print,library,librarytime,shipremarks',$order_str,$start,$perpage);			 //格式化数据            foreach ($info_listtt as $key=>$value) 		    {				$shop = $this->shop->read($value['shop']);				$info_listtt[$key]['shop'] = $shop['shopname'];				$express = $this->express->read($value['express']);				$info_listtt[$key]['express'] = $express['servicename'];				$warehouse = $this->warehouse->read($value['type']);				$info_listtt[$key]['type'] = $warehouse['title'];				$info_listtt[$key]['librarytime'] = '<em class="t">'.date('Y-m-d H:i:s',$value['librarytime']).'</em>';            }			$info_listxw = $this->fullorderxw->find_all($where,'id,shop,type,orderinfo,number,waybill,express,print,library,librarytime,shipremarks',$order_str,$start,$perpage);			 //格式化数据            foreach ($info_listxw as $key=>$value) 		    {				$shop = $this->shop->read($value['shop']);				$info_listxw[$key]['shop'] = $shop['shopname'];				$express = $this->express->read($value['express']);				$info_listxw[$key]['express'] = $express['servicename'];				$warehouse = $this->warehouse->read($value['type']);				$info_listxw[$key]['type'] = $warehouse['title'];				$info_listxw[$key]['librarytime'] = '<em class="t">'.date('Y-m-d H:i:s',$value['librarytime']).'</em>';            }			$info_listsmt = $this->fullordersmt->find_all($where." and mergeid = '0'",'id,shop,type,orderinfo,number,waybill,express,print,library,librarytime,shipremarks',$order_str,$start,$perpage);			 //格式化数据            foreach ($info_listsmt as $key=>$value) 		    {				$shop = $this->shop->read($value['shop']);				$info_listsmt[$key]['shop'] = $shop['shopname'];				$express = $this->express->read($value['express']);				$info_listsmt[$key]['express'] = $express['servicename'];				$warehouse = $this->warehouse->read($value['type']);				$info_listsmt[$key]['type'] = $warehouse['title'];				$info_listsmt[$key]['librarytime'] = '<em class="t">'.date('Y-m-d H:i:s',$value['librarytime']).'</em>';            }		    $total = $this->fullorder->find_count($where);			$total += $this->fullordertt->find_count($where);			$total += $this->fullorderxw->find_count($where);			$total += $this->fullordersmt->find_count($where);		    $pagenum = ceil($total/$perpage);		    $over = $total-($start+$perpage);		    $rows = array('total'=>$total,'over'=>$over,'pagenum'=>$pagenum,'rows'=>(array_merge($info_list,$info_listtt,$info_listxw,$info_listsmt)));		    echo json_encode($rows);exit;		}		if(isset($_SESSION['api']))		{			$wlshop = $this->shop->find_all('1=1 and '.rtrim($sid,'or'));			$warehouse = $this->warehouse->find_all('1=1 and '.rtrim($wid,'or'),"*","px asc");		    $this->data['wlshop'] = $wlshop;		    $this->data['warehouse'] = $warehouse;		}		$this->data['xw'] = $xw;		$this->_Template('systemfout_fouthb',$this->data);	}			public function _hb()	{		$post = $this->input->post(NULL, TRUE);		$xw = '';		if(isset($_SESSION['api']))		{			$user = $this->user->get_api($_SESSION['api']);			$usp = $user;		    $fgshop = "";$sid = "";$wid="";$wtype="";		    $usersp = explode('|',trim($user['shop'],'|'));			$userwh = explode('|',trim($user['warehouse'],'|'));			foreach ($usersp as $value) 		    {				$fgshop .= " shop = ".$value." or";				$sid .= " id = ".$value." or";			}			foreach ($userwh as $value) 		    {				$wid .= " id = ".$value." or";				$wtype .= " type = ".$value." or";			}			if($user['userid'] == 'xw')			{				$xw = 1;			}		}		if(isset($post['page']))  		{		    $page = $this->input->post('page',true);		    $perpage = $this->input->post('perpage',true);			$timetk = $this->input->post('timetk',true);			$timetj = $this->input->post('timetj',true);			$shop = $this->input->post('shop',true);			$source = $this->input->post('source',true);			$orderinfo = $this->input->post('orderinfo',true);			$number = $this->input->post('number',true);			$library = $this->input->post('library',true);			$waybill = $this->input->post('waybill',true);			$express = $this->input->post('express',true);			$type = $this->input->post('type',true);			$lowe = $this->input->post('lowe',true);			$so = $this->input->post('so',true);			$librarytime = $this->input->post('librarytime',true);			$timetk = strtotime($timetk);			$timetj = strtotime($timetj);			$cxtime = 'id';			$where = (isset($_SESSION['api']))?"library!=3 and mergeid = 1 and libraryconfirm=2 and print = 3 and (".rtrim($wtype,'or').")":"id = '0' and mergeid = 1";			if($timetk && $timetj && $library == 1)            {				//$cxtime = 'reviewtime';                $where  .= "  and printtime > '$timetk - 180*24*3600' and printtime < '$timetj'";				$where  .= " and state != 217";				            }			else if($timetk && $timetj && $library == 2)            {				$cxtime = 'librarytime';                $where  .= " and librarytime > '$timetk' and librarytime < '$timetj'";            }			if($shop)            {                $where  .= " and shop = '$shop'";            }			if($number)            {                $where  .= " and number = '$number'";            }			if($library)            {                $where  .= " and library = '$library'";            }			if($waybill)            {                $where  .= " and waybill = '$waybill'";            }			if($express)            {				$where  .= " and express = '$express'";            }			if($orderinfo)            {                $where  .= " and orderinfo = '$orderinfo'";            }			if($type)            {                $where  .= " and type = '$type'";            }			if($lowe)            {                $where  .= " and shipremarks like '%$lowe%'";            }			if($so)            {                $where  .= " and shipremarks like '%$so%'";            }            //数据排序            $order_str = $cxtime." desc";            if(empty($page))		    {                $start = 0;		    	$perpage = 1;            }		    else		    {                $start = ($page - 1)*$perpage;            }            //取得信息列表            $info_list = $this->fullorder->find_all($where,'id,shop,type,orderinfo,number,waybill,express,print,library,librarytime,orderremarks',$order_str,$start,$perpage);			 //格式化数据            foreach ($info_list as $key=>$value)		    {				$shop = $this->shop->read($value['shop']);				$info_list[$key]['shop'] = $shop['shopname'];				if($value['waybill'] == '0')				{					$info_list[$key]['waybill'] = "";				}				$express = $this->express->read($value['express']);				$info_list[$key]['express'] = $express['servicename'];				$warehouse = $this->warehouse->read($value['type']);				$info_list[$key]['type'] = $warehouse['title'];				if($value['print'] == 1)				{					$info_list[$key]['print'] = '不可打印';				}				else if($value['print'] == 2)				{					$info_list[$key]['print'] = '未打印';				}				else if($value['print'] == 3)				{					$info_list[$key]['print'] = '已打印';				}				if($value['library'] == 1)				{					$info_list[$key]['library'] = '<em class="c">未出库</em>';				}				else if($value['library'] == 2)				{					$info_list[$key]['library'] = '<em class="c">已出库</em>';				}				else if($value['library'] == 3)				{					$info_list[$key]['library'] = '<em class="c">已退库</em>';				}				if($value['librarytime'] == '0')				{					$info_list[$key]['librarytime'] = '<em class="t"></em>';				}				else				{					$info_list[$key]['librarytime'] = '<em class="t">'.date('Y-m-d H:i',$value['librarytime']).'</em>';				}				$info_list[$key]['orderremarks'] = str_replace(array('<','>'),array('<','>'),$value['orderremarks']);            }			$info_listtt = $this->fullordertt->find_all($where,'id,shop,type,orderinfo,number,waybill,express,print,library,librarytime,orderremarks',$order_str,$start,$perpage);			 //格式化数据            foreach ($info_listtt as $key=>$value) 		    {				$shop = $this->shop->read($value['shop']);				$info_listtt[$key]['shop'] = $shop['shopname'];				if($value['waybill'] == '0')				{					$info_listtt[$key]['waybill'] = "";				}				$express = $this->express->read($value['express']);				$info_listtt[$key]['express'] = $express['servicename'];				$warehouse = $this->warehouse->read($value['type']);				$info_listtt[$key]['type'] = $warehouse['title'];				if($value['print'] == 1)				{					$info_listtt[$key]['print'] = '不可打印';				}				else if($value['print'] == 2)				{					$info_listtt[$key]['print'] = '未打印';				}				else if($value['print'] == 3)				{					$info_listtt[$key]['print'] = '已打印';				}				if($value['library'] == 1)				{					$info_listtt[$key]['library'] = '<em class="c">未出库</em>';				}				else if($value['library'] == 2)				{					$info_listtt[$key]['library'] = '<em class="c">已出库</em>';				}				else if($value['library'] == 3)				{					$info_listtt[$key]['library'] = '<em class="c">已退库</em>';				}				if($value['librarytime'] == '0')				{					$info_listtt[$key]['librarytime'] = '<em class="t"></em>';				}				else				{					$info_listtt[$key]['librarytime'] = '<em class="t">'.date('Y-m-d H:i:s',$value['librarytime']).'</em>';				}            }			$info_listxw = $this->fullorderxw->find_all($where,'id,shop,type,orderinfo,number,waybill,express,print,library,librarytime,orderremarks',$order_str,$start,$perpage);			 //格式化数据            foreach ($info_listxw as $key=>$value) 		    {				$shop = $this->shop->read($value['shop']);				$info_listxw[$key]['shop'] = $shop['shopname'];				if($value['waybill'] == '0')				{					$info_listxw[$key]['waybill'] = "";				}				$express = $this->express->read($value['express']);				$info_listxw[$key]['express'] = $express['servicename'];				$warehouse = $this->warehouse->read($value['type']);				$info_listxw[$key]['type'] = $warehouse['title'];				if($value['print'] == 1)				{					$info_listxw[$key]['print'] = '不可打印';				}				else if($value['print'] == 2)				{					$info_listxw[$key]['print'] = '未打印';				}				else if($value['print'] == 3)				{					$info_listxw[$key]['print'] = '已打印';				}				if($value['library'] == 1)				{					$info_listxw[$key]['library'] = '<em class="c">未出库</em>';				}				else if($value['library'] == 2)				{					$info_listxw[$key]['library'] = '<em class="c">已出库</em>';				}				else if($value['library'] == 3)				{					$info_listxw[$key]['library'] = '<em class="c">已退库</em>';				}				if($value['librarytime'] == '0')				{					$info_listxw[$key]['librarytime'] = '<em class="t"></em>';				}				else				{					$info_listxw[$key]['librarytime'] = '<em class="t">'.date('Y-m-d H:i:s',$value['librarytime']).'</em>';				}            }			$info_listsmt = $this->fullordersmt->find_all($where." and mergeid = '0'",'id,shop,type,orderinfo,number,waybill,express,print,library,librarytime,orderremarks',$order_str,$start,$perpage);			 //格式化数据            foreach ($info_listsmt as $key=>$value) 		    {				$shop = $this->shop->read($value['shop']);				$info_listsmt[$key]['shop'] = $shop['shopname'];				if($value['waybill'] == '0')				{					$info_listsmt[$key]['waybill'] = "";				}				$express = $this->express->read($value['express']);				$info_listsmt[$key]['express'] = $express['servicename'];				$warehouse = $this->warehouse->read($value['type']);				$info_listsmt[$key]['type'] = $warehouse['title'];				if($value['print'] == 1)				{					$info_listsmt[$key]['print'] = '不可打印';				}				else if($value['print'] == 2)				{					$info_listsmt[$key]['print'] = '未打印';				}				else if($value['print'] == 3)				{					$info_listsmt[$key]['print'] = '已打印';				}				if($value['library'] == 1)				{					$info_listsmt[$key]['library'] = '<em class="c">未出库</em>';				}				else if($value['library'] == 2)				{					$info_listsmt[$key]['library'] = '<em class="c">已出库</em>';				}				else if($value['library'] == 3)				{					$info_listsmt[$key]['library'] = '<em class="c">已退库</em>';				}				if($value['librarytime'] == '0')				{					$info_listsmt[$key]['librarytime'] = '<em class="t"></em>';				}				else				{					$info_listsmt[$key]['librarytime'] = '<em class="t">'.date('Y-m-d H:i:s',$value['librarytime']).'</em>';				}            }		    $total = $this->fullorder->find_count($where);			$total += $this->fullordertt->find_count($where);			$total += $this->fullorderxw->find_count($where);			$total += $this->fullordersmt->find_count($where);		    $pagenum = ceil($total/$perpage);		    $over = $total-($start+$perpage);		    $rows = array('total'=>$total,'over'=>$over,'pagenum'=>$pagenum,'rows'=>(array_merge($info_list,$info_listtt,$info_listxw,$info_listsmt)));		    echo json_encode($rows);exit;		}		if(isset($_SESSION['api']))		{			$wlshop = $this->shop->find_all('1=1 and '.rtrim($sid,'or'));			$warehouse = $this->warehouse->find_all('1=1 and '.rtrim($wid,'or'),"*","px asc");		    $this->data['wlshop'] = $wlshop;		    $this->data['warehouse'] = $warehouse;		}		$this->data['xw'] = $xw;		$this->_Template('systemfout_hb',$this->data);	}}
 |