DICOM服务中的C-STORE、 C-FIND、C-MOVE、C-GET、Worklist
DICOM服务说明
DICOM(Digital Imaging and Communications in Medicine)是一种用于处理、存储、打印和传输医学影像的标准。DICOM定义了多种服务类,其中C-STORE、C-FIND、C-MOVE和C-GET是与影像数据查询和检索相关的四个主要服务类:
C-STORE
用于存储一个DICOM对象实例到远程DICOM应用实体。这意味着可以将图像或其它类型的DICOM数据发送到服务器进行存储。
C-FIND
用于执行匹配查询,即在远程DICOM应用实体中查找符合特定条件的DICOM对象实例。
C-MOVE
允许用户请求从一个AE(Application Entity)向另一个AE传输指定的DICOM对象实例。它通常用于请求影像从服务器传输到本地系统或其他指定位置。
C-MOVE是DICOM标准中Query/Retrieve Service Class的一部分,主要用于在DICOM兼容设备之间请求和转移医学图像数据。当使用C-MOVE时,客户端(比如一个工作站)可以向服务器(如PACS系统)发送一个请求,要求服务器将特定的DICOM对象复制到另一个指定的目标节点。以下是C-MOVE操作的基本步骤:
- 查询: 客户端首先查询服务器以找到满足特定条件的DICOM对象。
- 移动请求: 然后,客户端发送一个C-MOVE请求给服务器,指定了目标节点(即接收数据的另一台机器)以及想要获取的数据集。
- 数据传输: 服务器接收到C-MOVE请求后,会主动将指定的数据集发送到目标节点。
这种机制非常适合于医院内部或医疗机构之间的影像数据共享,因为它允许用户从远程位置请求并接收所需的影像资料,而无需手动下载和上传文件。
C-GET
类似于C-MOVE,但不同之处在于C-GET请求的数据直接返回给请求者,而不是由服务器推送到另一个目的地。
Worklist获取(Modality Worklist)
这不是一种DICOM传输服务,而是一种查询服务,用于从RIS(Radiology Information System)或医院信息系统(HIS)中获取患者信息和检查计划列表,以供成像设备使用。这有助于减少手动输入错误并提高效率。
DICOM服务C#基本示例
//C-STORE 示例
using FellowOakDicom;
using FellowOakDicom.Network;
using System.Threading.Tasks;
public class StoreExample
{
public async Task StoreImageAsync(string filePath, string remoteAETitle, string remoteHost, int remotePort)
{
var file = DicomFile.Open(filePath);
var client = new DicomClient();
await client.AddRequestAsync(new DicomCStoreRequest(file)
{
OnSuccess = (request, response) =>
{
// 成功回调
return Task.CompletedTask;
},
OnError = (request, response) =>
{
// 错误回调
return Task.CompletedTask;
}
});
await client.SendAsync(remoteAETitle, remoteHost, remotePort);
}
}
//C-FIND 示例
using FellowOakDicom.Network;
using System.Threading.Tasks;
public class FindExample
{
public async Task QueryStudiesAsync(string remoteAETitle, string remoteHost, int remotePort)
{
var client = new DicomClient();
var request = new DicomCFindRequest(DicomPriority.Low)
{
SOPClassUID = DicomUID.StudyRootQueryRetrieveInformationModelFIND
};
request.Dataset.AddOrUpdate(DicomTag.PatientName, "*");
request.OnResponseReceived = (req, res) =>
{
// 处理响应
return Task.CompletedTask;
};
await client.AddRequestAsync(request);
await client.SendAsync(remoteAETitle, remoteHost, remotePort);
}
}
//C-MOVE 示例:C-MOVE请求用于从一个AE(Application Entity)向另一个AE传输指定的DICOM对象实例。
using FellowOakDicom.Network;
using System.Threading.Tasks;
public class MoveExample
{
public async Task MoveImagesAsync(string remoteAETitle, string remoteHost, int remotePort, string destinationAETitle)
{
var client = new DicomClient();
var request = new DicomCMoveRequest(DicomUID.StudyRootQueryRetrieveInformationModelMOVE, destinationAETitle)
{
SOPInstanceUID = "*",
StudyInstanceUID = "1.2.840.113619.2.1.9999.7556.1234567890", // 示例Study Instance UID
OnResponseReceived = (req, res) =>
{
// 处理响应
return Task.CompletedTask;
}
};
await client.AddRequestAsync(request);
await client.SendAsync(remoteAETitle, remoteHost, remotePort);
}
}
//C-GET 示例:C-GET请求直接从查询/检索模型获取匹配的DICOM实例并将其返回给请求者。
using FellowOakDicom.Network;
using System.Threading.Tasks;
public class GetExample
{
public async Task GetImagesAsync(string remoteAETitle, string remoteHost, int remotePort)
{
var client = new DicomClient();
var request = new DicomCGetRequest(DicomUID.StudyRootQueryRetrieveInformationModelGET)
{
StudyInstanceUID = "1.2.840.113619.2.1.9999.7556.1234567890", // 示例Study Instance UID
OnResponseReceived = (request, response) =>
{
// 处理每个接收到的DICOM文件
if (response.Dataset != null)
{
var file = new DicomFile(response.Dataset);
// 保存或处理DICOM文件
}
return Task.CompletedTask;
},
OnCompleted = () =>
{
// 所有数据接收完毕后的处理
return Task.CompletedTask;
}
};
await client.AddRequestAsync(request);
await client.SendAsync(remoteAETitle, remoteHost, remotePort);
}
}