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操作的基本步骤:

  1. 查询: 客户端首先查询服务器以找到满足特定条件的DICOM对象。
  2. 移动请求: 然后,客户端发送一个C-MOVE请求给服务器,指定了目标节点(即接收数据的另一台机器)以及想要获取的数据集。
  3. 数据传输: 服务器接收到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);
    }
}

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wangnaisheng

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值