[英]What is the error in the following HL7 encoding?
我正在嘗試使用OpenMRS模塊的HAPI 2.0庫對ORU_R01類型的HL7消息進行編碼。 我遵循了HAPI文檔中提供的教程,並據此填充了ORU_R01消息的必填字段。 現在,我想使用以下鏈接發布此消息:
http://localhost:8080/openmrs/remotecommunication/postHl7.form
我正在使用以下消息進行測試:
MSH|^~\&|||||20140713154042||ORU^R01|20140713154042|P|2.5|1
PID|||1
OBR|1||1234^SensorReading|88304
OBX|0|NM|1||45
OBX|1|NM|2||34
OBX|2|NM|3||23
我已正確確保所有參數均正確。 一旦發布了HL7消息,便從調度程序啟動HL7任務。 然后,我進入管理頁面並單擊“管理HL7錯誤”,以查看消息是否到達那里。 我得到以下堆棧跟蹤:
ca.uhn.hl7v2.HL7Exception: HL7 encoding not supported
...
Caused by: ca.uhn.hl7v2.parser.EncodingNotSupportedException: Can't parse message beginning MSH|^~\
at ca.uhn.hl7v2.parser.Parser.parse(Parser.java:140)
完整的堆棧跟蹤位於此處: http : //pastebin.com/ZnbFqfWC 。 我編寫了以下代碼來編碼HL7消息(使用HAPI庫):
public String createHL7Message(int p_id, int concept_id[], String val[])
throws HL7Exception {
ORU_R01 message = new ORU_R01();
SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmss",
Locale.ENGLISH);
MSH msh = message.getMSH();
msh.getFieldSeparator().setValue("|");
msh.getEncodingCharacters().setValue("^~\\&");
msh.getProcessingID().getProcessingID().setValue("P");
msh.getSequenceNumber().setValue("1");
msh.getMessageType().getTriggerEvent().setValue("R01");
msh.getMessageType().getMessageCode().setValue("ORU");
msh.getVersionID().getVersionID().setValue("2.5");
msh.getMessageControlID().setValue(
sdf.format(Calendar.getInstance().getTime()));
msh.getDateTimeOfMessage().getTime()
.setValue(sdf.format(Calendar.getInstance().getTime()));
ORU_R01_ORDER_OBSERVATION orderObservation = message
.getPATIENT_RESULT().getORDER_OBSERVATION();
ca.uhn.hl7v2.model.v25.segment.PID pid = message.getPATIENT_RESULT()
.getPATIENT().getPID();
Patient patient = (Patient) Context.getPatientService()
.getPatient(p_id);
System.out.println(String.valueOf(p_id) + " " + patient.getGivenName()
+ " " + patient.getFamilyName());
pid.getPatientName(0).getFamilyName().getSurname()
.setValue(patient.getFamilyName());
pid.getPatientName(0).getGivenName().setValue(patient.getGivenName());
pid.getPatientIdentifierList(0).getIDNumber()
.setValue(String.valueOf(p_id));
System.out.println();
// Parser parser = new PipeParser();
// String encodedMessage = null;
// encodedMessage = parser.encode(message);
// System.out.println(encodedMessage);
// Populate the OBR
OBR obr = orderObservation.getOBR();
obr.getSetIDOBR().setValue("1");
obr.getFillerOrderNumber().getEntityIdentifier().setValue("1234");
obr.getFillerOrderNumber().getNamespaceID().setValue("SensorReading");
obr.getUniversalServiceIdentifier().getIdentifier().setValue("88304");
Varies value = null;
// Varies value[] = new Varies[4];
for (int i = 0; i < concept_id.length; i++) {
ORU_R01_OBSERVATION observation = orderObservation
.getOBSERVATION(i);
OBX obx2 = observation.getOBX();
obx2.getSetIDOBX().setValue(String.valueOf(i));
obx2.getObservationIdentifier().getIdentifier()
.setValue(String.valueOf(concept_id[i]));
obx2.getValueType().setValue("NM");
NM nm = new NM(message);
nm.setValue(val[i]);
value = obx2.getObservationValue(0);
value.setData(nm);
}
Parser parser = new PipeParser();
String encodedMessage = null;
encodedMessage = parser.encode(message);
return encodedMessage;
}
消息的MSH段很可能出了點問題,但是我似乎無法弄清楚它是什么。 我該怎么做才能糾正此錯誤?
為什么要使用雙反斜杠聲明編碼字符?
msh.getEncodingCharacters().setValue("^~\\\\&");
不應該是:
msh.getEncodingCharacters().setValue("^~\\&");
...並且因為您的消息使用的是默認編碼字符,也許您根本不需要聲明它們? 從HAPI MSH類參考中摘錄
getENCODINGCHARACTERS
public ST getENCODINGCHARACTERS()
Returns MSH-2: "ENCODING CHARACTERS" - creates it if necessary
更新我以前沒有使用HAPI的經驗。 一個快速的谷歌找到了一個ORU的例子 。 您可以嘗試使用initQuickstart("ORU", "R01", "P");
初始化MSH initQuickstart("ORU", "R01", "P");
根據示例代碼中的注釋,initQuickstart方法將填充消息的MSH段中的所有必填字段,包括消息類型,時間戳和控件ID。 (...希望也可以使用默認編碼chars :-)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.