#define _CRT_SECURE_NO_WARNINGS #include "epm_handler_common.h" bool isItemStart = true; void getItemProperty(tag_t bomLine, map typePropertyType, char parameters[100000]); void getTCMItemBom(tag_t item, map typePropertyType, char parameters[100000]); int ML_TCMSendSapItem(EPM_action_message_t msg) { printf("=========================对象下发到SAP Start===================\n"); auto startTime = std::chrono::high_resolution_clock::now(); //POM_AM__set_application_bypass(true); int ifail = ITK_ok; int attachments_num = 0; tag_t rootTask = NULLTAG, *attachments = NULLTAG; //获取任务对象 EPM_ask_root_task(msg.task, &rootTask); //获取任务目标对象 EPM_ask_attachments(rootTask, EPM_target_attachment, &attachments_num, &attachments); //获取参数 char *argflag = NULL, *argvalue = NULL, *arg = NULL; char messageUser[1024] = "", messageResult[1024] = ""; int arg_cnt = TC_number_of_arguments(msg.arguments); printf("参数个数为:%d\n", arg_cnt); if (arg_cnt > 0) { for (int i = 0; i messageUserValues; if (strstr(messageUser, ",") != NULL) { int vectorValueCount = 0; char ** vectorValueChar = new char *[64]; split(messageUser, ",", vectorValueChar, &vectorValueCount); for (int i = 0; i < vectorValueCount; i++) { messageUserValues.push_back(vectorValueChar[i]); } } else { messageUserValues.push_back(messageUser); } int pref_cnt = 0; char ** pref_vals = NULL; //获取首选项的值 PREF_ask_char_values("ML_ItemSendSapProperty", &pref_cnt, &pref_vals); map typePropertyType; for (int j = 0; j < pref_cnt; j++) { if (strstr(pref_vals[j], "-") != NULL) { //按照-进行拆分。拆分条件 int valueCount = 0; char ** valueChar = new char *[64]; //分割字符串 split(pref_vals[j], "-", valueChar, &valueCount); typePropertyType[valueChar[0]] = valueChar[1];// .insert(std::pair(valueChar[0], valueChar[1])); } } bool isStart = true; char *tc_root_file = getenv("tc_root"); //C:\Siemens\Teamcenter11 isItemStart = true; char parameters[100000] = "";//写入到文件的值 strcat(parameters, "getItemPropertys}}"); strcat(parameters, "["); for (int i = 0; i < attachments_num; i++) { getTCMItemBom(attachments[i], typePropertyType, parameters); } strcat(parameters, "]"); //获取当前时间 time_t now = time(0); tm *p = localtime(&now); char date[128] = ""; sprintf_s(date, "%04d%02d%02d%02d%02d%02d", 1900 + p->tm_year, p->tm_mon + 1, p->tm_mday, p->tm_hour, p->tm_min, p->tm_sec); //把数据用写入文件 char data_file[SS_MAXPATHLEN] = ""; strcat(data_file, tc_root_file); strcat(data_file, "\\"); strcat(data_file, date); strcat(data_file, ".txt"); ofstream file; file.open(data_file); file << parameters << endl; // 使用与cout同样的方式进行写入 file.close(); string strResult; //cmd指令 char cmd[256] = ""; strcpy(cmd, "java -jar \""); //strcat(cmd, jar_file); strcat(cmd, tc_root_file); strcat(cmd, "\\portal\\plugins\\"); strcat(cmd, "ML_SendSap.jar"); strcat(cmd, "\" "); //传参 cout << data_file << endl; strcat(cmd, data_file); //用来传递本流程的流程名称(@分割) //strcat(cmd,"@"); //strcat(cmd,handler_name); printf("路径:\n%s\n", cmd); char buf[8000] = { 0 }; FILE *pf = NULL; if ((pf = _popen(cmd, "r")) == NULL) { printf("接口返回:\n%s", "1"); } while (fgets(buf, sizeof buf, pf)) { strResult += buf; } _pclose(pf); cout << strResult << endl; unsigned int iSize = strResult.size(); if (iSize > 0 && strResult[iSize - 1] == '\n' && strlen(parameters) > 0) { strResult = strResult.substr(0, iSize - 1); printf("下发失败\n"); cout << strResult << endl; //发送消息到企业微信 for (auto messageUserValue : messageUserValues) { itemSendToWeixin(messageUserValue, rootTask, strResult); } if (strcmp(messageResult, "1") == 0) { ifail = 1; } } else { POM_AM__set_application_bypass(TRUE); //获取首次发送时间 for (int i = 0; i < attachments_num; i++) { char *itemType = NULL; AOM_ask_value_string(attachments[i], "object_type", &itemType); //过滤掉非版本的对象 if ((strcmp(itemType, "ML8_RefrigeratorRevision") == 0) || (strcmp(itemType, "ML8_WashingRevision") == 0) || (strcmp(itemType, "ML8_ColdRevision") == 0) || (strcmp(itemType, "ML8_OthersRevision") == 0) || (strcmp(itemType, "ML8_PartRevision") == 0) || (strcmp(itemType, "ML8_RawMaterialRevision") == 0) || (strcmp(itemType, "ML8_UnProductRevision") == 0) || (strcmp(itemType, "ML8_ProductOthRevision") == 0)) { } DOFREE(itemType); } POM_AM__set_application_bypass(FALSE); } messageUserValues.clear(); vector().swap(messageUserValues); MEM_free(attachments); tc_root_file = NULL; pref_vals = NULL; if (ifail == 1) { EMH_store_error_s1(EMH_severity_user_error, EMH_USER_error_base, strResult.c_str()); } auto stopTime = std::chrono::high_resolution_clock::now(); auto duration = std::chrono::duration_cast(stopTime - startTime); //std::cout << "ML_TCMSendSapItem用时:" << duration.count() / 1000 << std::endl; string usetime = "ML_TCMSendSapItem用时:"; usetime.append(std::to_string(duration.count() / 1000)); WriteLog(true, usetime.c_str()); printf("=========================对象下发到SAP End===================\n"); return ifail; } void getTCMItemBom(tag_t item, map typePropertyType, char parameters[100000]) { char *itemType = NULL; AOM_ask_value_string(item, "object_type", &itemType); printf("itemType%s Start===================\n", itemType); //过滤掉非版本的对象 if ((strcmp(itemType, "ML8_RefrigeratorRevision") == 0) || (strcmp(itemType, "ML8_WashingRevision") == 0) || (strcmp(itemType, "ML8_ColdRevision") == 0) || (strcmp(itemType, "ML8_OthersRevision") == 0) || (strcmp(itemType, "ML8_PartRevision") == 0) || (strcmp(itemType, "ML8_RawMaterialRevision") == 0)) { //获取所有包含替代项目组的BOM行 vector bomLines; //获取子项 tag_t top_line = NULLTAG, window = NULLTAG; BOM_create_window(&window); //设置顶层BOM BOM_set_window_top_line(window, NULLTAG, item, NULLTAG, &top_line); int count; tag_t *children_line; BOM_line_ask_all_child_lines(top_line, &count, &children_line); if (count > 0) { for (int i = 0; i < count; i++) { getItemProperty(children_line[i], typePropertyType, parameters); } } BOM_close_window(window); /*MEM_free(addTrade); MEM_free(processingMode); MEM_free(childItem);*/ } MEM_free(itemType); } void getItemProperty(tag_t bomLine, map typePropertyType, char parameters[100000]) { tag_t item = NULLTAG; AOM_ask_value_tag(bomLine, "bl_line_object", &item); char *itemType = NULL; AOM_ask_value_string(item, "object_type", &itemType); printf("itemType:%s\n", itemType); //过滤掉非版本的对象 if ((strcmp(itemType, "ML8_PrMidItemRevision") == 0)) { string propertyNames = typePropertyType[itemType]; if (propertyNames.c_str() != NULL) { if (isItemStart) { strcat(parameters, "{"); isItemStart = false; } else { strcat(parameters, ",{"); } const char * constName = propertyNames.c_str(); char* name = new char[2048];//足够长 strcpy(name, constName); if (strstr(name, ",") != NULL) { //按照,进行拆分。拆分条件 int valueCount = 0; char ** valueChar = new char *[64]; //分割字符串 split(name, ",", valueChar, &valueCount); for (int k = 0; k < valueCount; k++) { if (strstr(valueChar[k], "=") != NULL) { //按照-进行拆分。拆分条件 int valueNum = 0; char ** values = new char *[64]; //分割字符串 split(valueChar[k], "=", values, &valueNum); strcat(parameters, "\""); strcat(parameters, values[1] == NULL || strlen(values[1]) == 0 ? "" : values[1]); strcat(parameters, "\""); strcat(parameters, ":"); char * item_rev_value = NULL; TCGetPropertyValue(item, "Revision", values[0], &item_rev_value); if (strcmp(values[1], "matltype") == 0) { //物料类型特殊处理,判断是否是零件和原辅材料 if ((strcmp(itemType, "ML8_PartRevision") == 0) || (strcmp(itemType, "ML8_RawMaterialRevision") == 0) || (strcmp(itemType, "ML8_UnProductRevision") == 0)) { char * processingMode = NULL; //获取加工方式 TCGetPropertyValue(item, "Revision", "rev.ml8_ProcessingMode", &processingMode); if (strcmp(processingMode, "自制") == 0) { item_rev_value = "HALB"; } else { item_rev_value = "ROH"; } DOFREE(processingMode); } } if (strcmp(values[1], "uom") == 0) { if (item_rev_value == NULL || strcmp(item_rev_value, "") == 0) { item_rev_value = "ea"; } else { if (strcmp(item_rev_value, "Eac") == 0 || strcmp(item_rev_value, "Each.") == 0) { item_rev_value = "ea"; } } } if (strstr(item_rev_value, "\"") != NULL) { string resultString = replace_all_distinct(item_rev_value, "\"", "\\\""); char resultChar[256] = ""; strcpy(resultChar, resultString.c_str()); *(resultChar + strlen(resultString.c_str())) = '\0'; item_rev_value = resultChar; } strcat(parameters, "\""); strcat(parameters, item_rev_value); strcat(parameters, "\""); if (k < valueCount - 1) { strcat(parameters, ","); } DOFREE(item_rev_value); values = NULL; } printf("parameters:%s\n", parameters); } valueChar = NULL; } else { //按照-进行拆分。拆分条件 int valueCount = 0; char ** valueChar = new char *[64]; //分割字符串 split(name, "=", valueChar, &valueCount); strcat(parameters, "\""); strcat(parameters, valueChar[1] == NULL || strlen(valueChar[1]) == 0 ? "" : valueChar[1]); strcat(parameters, "\""); strcat(parameters, ":"); char * item_rev_value = NULL; TCGetPropertyValue(item, "Revision", valueChar[0], &item_rev_value); if (strcmp(valueChar[1], "matltype") == 0) { //物料类型特殊处理,判断是否是零件和原辅材料 if ((strcmp(itemType, "ML8_PartRevision") == 0) || (strcmp(itemType, "ML8_RawMaterialRevision") == 0) || (strcmp(itemType, "ML8_UnProductRevision") == 0)) { char * processingMode = NULL; //获取加工方式 TCGetPropertyValue(item, "Revision", "rev.ml8_ProcessingMode", &processingMode); if (strcmp(processingMode, "自制") == 0) { item_rev_value = "HALB"; } else { item_rev_value = "ROH"; } DOFREE(processingMode); } } if (strcmp(valueChar[1], "uom") == 0) { if (item_rev_value == NULL || strcmp(item_rev_value, "") == 0) { item_rev_value = "ea"; } else { if (strcmp(item_rev_value, "Eac") == 0 || strcmp(item_rev_value, "Each.") == 0) { item_rev_value = "ea"; } } } if (strstr(item_rev_value, "\"") != NULL) { string resultString = replace_all_distinct(item_rev_value, "\"", "\\\""); char resultChar[256] = ""; strcpy(resultChar, resultString.c_str()); *(resultChar + strlen(resultString.c_str())) = '\0'; item_rev_value = resultChar; } strcat(parameters, "\""); strcat(parameters, item_rev_value); strcat(parameters, "\""); DOFREE(item_rev_value); valueChar = NULL; } strcat(parameters, "}"); DOFREE(constName); name = NULL; } } else { getTCMItemBom(item, typePropertyType, parameters); } DOFREE(itemType); }