金蝶系統是強大的財務系統,可對公司的財務進行整理,所以有的時候需要去我php系統來對接金蝶系統,為金蝶系統生成各種單據。下面是php對接金蝶的流程。
各種方法已經封裝好,直接可以調用就行了。
1.如果是用的TP框架,請將下面的方法放在common.php中,方便系統調用。
1 /*****=======================================對接金蝶需要用到的方法==========================================================******/ 2 /** 3 * 利用curl函數來獲取接口數據 4 * @param $url 5 * @param $post_content 6 * @param $cookie_jar 7 * @param $isLogin 8 * @return bool|string 9 */ 10 11 function invoke_post($url,$post_content,$cookie_jar,$isLogin) 12 { 13 $ch = curl_init($url); 14 15 $this_header = array( 16 'Content-Type: application/json', 17 'Content-Length: '.strlen($post_content) 18 ); 19 20 curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'POST'); 21 curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); 22 curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); 23 24 curl_setopt($ch, CURLOPT_HTTPHEADER, $this_header); 25 curl_setopt($ch, CURLOPT_POSTFIELDS, $post_content); 26 curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); 27 if($isLogin){ 28 curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_jar); 29 } 30 else{ 31 curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_jar); 32 } 33 curl_setopt($ch, CURLOPT_TIMEOUT, 30); 34 35 $result = curl_exec($ch); 36 curl_close($ch); 37 38 return $result; 39 } 40 41 //構造Web API請求格式 42 function create_postdata($args) { 43 $postdata = array( 44 'format'=>1, 45 'useragent'=>'ApiClient', 46 'rid'=>create_guid(), 47 'parameters'=>$args, 48 'timestamp'=>date('Y-m-d'), 49 'v'=>'1.0' 50 ); 51 52 return json_encode($postdata); 53 } 54 55 //生成guid 56 function create_guid() { 57 $charid = strtoupper(md5(uniqid(mt_rand(), true))); 58 $hyphen = chr(45);// "-" 59 $uuid = chr(123)// "{" 60 .substr($charid, 0, 8).$hyphen 61 .substr($charid, 8, 4).$hyphen 62 .substr($charid,12, 4).$hyphen 63 .substr($charid,16, 4).$hyphen 64 .substr($charid,20,12) 65 .chr(125);// "}" 66 return $uuid; 67 } 68 69 //登陸 70 function invoke_login($cloudUrl,$post_content,$cookie_jar) 71 { 72 $loginurl = $cloudUrl.'Kingdee.BOS.WebApi.ServicesStub.AuthService.ValidateUser.common.kdsvc'; 73 return invoke_post($loginurl,$post_content,$cookie_jar,TRUE); 74 } 75 76 //保存 77 function invoke_save($cloudUrl,$post_content,$cookie_jar) 78 { 79 $invokeurl = $cloudUrl.'Kingdee.BOS.WebApi.ServicesStub.DynamicFormService.Save.common.kdsvc'; 80 return invoke_post($invokeurl,$post_content,$cookie_jar,FALSE); 81 } 82 83 //審核 84 function invoke_audit($cloudUrl,$post_content,$cookie_jar) 85 { 86 $invokeurl = $cloudUrl.'Kingdee.BOS.WebApi.ServicesStub.DynamicFormService.Audit.common.kdsvc'; 87 return invoke_post($invokeurl,$post_content,$cookie_jar,FALSE); 88 } 89 90 //查看 91 function invoke_view($cloudUrl,$post_content,$cookie_jar) 92 { 93 $invokeurl = $cloudUrl.'Kingdee.BOS.WebApi.ServicesStub.DynamicFormService.View.common.kdsvc'; 94 return invoke_post($invokeurl,$post_content,$cookie_jar,FALSE); 95 } 96 /*****************************************對接金蝶的方法結束************************************************************/
2.將一些配置項直接在類里面定義好,避免重復多次的書寫
//類的創建根據自己的需要來自行創建 class OrderController extends BaseController { protected $cloudUrl = '自己金蝶的域名或者是IP地址/K3Cloud/'; protected $login = array('套賬id','賬號','密碼',2052); public function index(){ /*方法內部*/ } }
3.金蝶的所有操作都需要在登錄的狀態下進行操作 ,所以就需要先進行登錄操作。在你需要生成金蝶報表的時候添加如下的代碼:
/*對接金蝶系統,先做登錄,在登錄的會話下進行其他操作*/ $cookie_jar = tempnam('./tmp','CloudSession');//保存登錄后的session $post_content = create_postdata($this->login); /*返回登錄信息如果 LoginResultType == 1 說明登錄成功*/ $result = json_decode(invoke_login($this->cloudUrl,$post_content,$cookie_jar),true); /*判斷成功之后在進行其他操作*/ if($result['LoginResultType'] == 1){ /*在這里面進行金蝶報表的生成操作*/ }
4.登錄成功之后就可以進行報表的操作了,金蝶報表的操作主要靠json來操作,這個json一定要生成正確。這里給大家講一下怎樣做能盡量避免問題。
4.1 首先以開發者的身份登錄到金蝶賬號中,在右面的菜單中找到webAPI菜單

4.2 然后再左側選擇你要生成的報表的名稱,在右面選擇你要調用的接口,就會有相應的說明。

4.3 然后點擊上面的 在線測試webAPI 按鈕,出現調試框:

4.4然后選擇自己要調用的接口,來填寫測試數據。

4.5 填寫完成測試數據之后點擊返回數據就可以

4.6 返回的數據最好驗證下,避免有必填項遺漏掉。操作如下:

5. 數據格式沒問題之后就可以用代碼來生成金蝶訂單了。具體操作如下:
1 /*判斷成功之后在進行其他操作*/ 2 if($result['LoginResultType'] == 1){ 3 $data_model = '{ 4 "Creator": "", 5 "NeedUpDateFields": [], 6 "NeedReturnFields": [], 7 "IsDeleteEntry": "true", 8 "SubSystemId": "", 9 "IsVerifyBaseDataField": "false", 10 "IsEntryBatchFill": "true", 11 "ValidateFlag": "true", 12 "NumberSearch": "true", 13 "InterationFlags": "", 14 "IsAutoSubmitAndAudit": "false", 15 "Model": { 16 "FID": 0, 17 "FBillTypeID": { 18 "FNUMBER": "DKSKD000001" 19 }, 20 "FDATE": "2020-05-14 00:00:00", 21 "FCONTACTUNITTYPE": "BD_Customer", 22 "FPAYUNITTYPE": "BD_Customer", 23 "FCURRENCYID": { 24 "FNumber": "PRE001" 25 }, 26 "FPAYORGID": { 27 "FNumber": "100" 28 }, 29 "FSETTLERATE": 1.0, 30 "FSETTLEORGID": { 31 "FNumber": "100" 32 }, 33 "FSALEORGID": { 34 "FNumber": "100" 35 }, 36 "FDOCUMENTSTATUS": "Z", 37 "FBUSINESSTYPE": "1", 38 "FISINIT": false, 39 "FEXCHANGERATE": 1.0, 40 "FCancelStatus": "A", 41 "FSETTLECUR": { 42 "FNUMBER": "PRE001" 43 }, 44 "FISB2C": false, 45 "FIsWriteOff": false, 46 "FSETTLEMAINBOOKID": { 47 "FNUMBER": "PRE001" 48 }, 49 "FISCARRYRATE": false, 50 "FRECEIVEBILLENTRY": [ 51 { 52 "FPURPOSEID": { 53 "FNumber": "SFKYT01_SYS" 54 }, 55 "FPOSTDATE": "2020-05-14 00:00:00" 56 } 57 ] 58 } 59 }'; 60 $kingdee_info = array( 61 '你要操作訂單的表單號,測試的時候那個藍框里的內容',//業務對象標識FormId 報表不同 表單號不同,切記 62 $data_model//具體Json字串 63 ); 64 $post_content = create_postdata($kingdee_info); 65 66 $res = json_decode(invoke_save($this->cloudUrl,$post_content,$cookie_jar),true) ; 67 //可以打印$res來查看自己的報表生成結果 68 }
6.到此,金蝶的報表生成就結束了,需要注意的是$data_model 的json中的數據 需要換成自己的數據。注意:金蝶里好多字段都是金蝶的編碼,要做好本地系統和金蝶系統的編碼對應。寫的不好,大家不喜勿噴。或者大家有什么需要補充的可以聯系我QQ:2280037846。
也可以在下面留言。我會在第一時間回復大家
