WorklistQuery (C-FIND) возвращает ответ C-Find [2]: необязательные ключи не поддерживаются - PullRequest
0 голосов
/ 09 февраля 2019

C-Find (запрос рабочего списка) для конкретной PACS возвращает «Необязательные ключи не поддерживаются» и не возвращает данных.Я также попытался использовать пустую строку "" вместо нуля для идентификатора пациента, существующего патиентида и т. Д. С тем же результатом.Запрос работает для других PACS.

Что здесь происходит и как это можно решить?

Код запроса (с использованием языка Fellow Oak DICOM fo):

var cfind = DicomCFindRequest.CreateWorklistQuery();

List<Dicom.DicomDataset> dslist = new List<Dicom.DicomDataset>();

cfind.OnResponseReceived = (DicomCFindRequest rq, DicomCFindResponse rp) =>
{

    if (rp.Status != DicomStatus.Pending)
    {                 
        return;
    }           

    dslist.Add(rp.Dataset);
};

var client = new DicomClient();
client.AddRequest(cfind);

try
{                
    await client.SendAsync(destip, port, useTLS, callingAE, calledAE);
}
catch (Exception e)
{
    logger.Error(e);                
}

Это журнал.

2019-02-09 09:49:01.6540 INFO Dicom.Log.NLogManager+NLogger.Log TEST_01WL -> Association request:

Calling AE Title:       XXXXXXXXX

Called AE Title:        TEST_01WL

Remote host:            XXX.29.51.XXX

Remote port:            9895

Implementation Class:   Implementation Class UID [1.3.6.1.4.1.30071.8]

Implementation Version: fo-dicom 4.0.0

Maximum PDU Length:     16384

Async Ops Invoked:      1

Async Ops Performed:    1

Presentation Contexts:  1

  Presentation Context:  1 [Proposed]

       Abstract Syntax:  Modality Worklist Information Model - FIND

       Transfer Syntax:  Implicit VR Little Endian: Default Transfer Syntax for 
DICOM 

2019-02-09 09:49:01.6540 INFO Dicom.Log.NLogManager+NLogger.Log TEST_01WL <- Association accept:

Calling AE Title:       XXXXXXXXX

Called AE Title:        TEST_01WL

Remote host:            XXX.29.51.XXX

Remote port:            9895

Implementation Class:   Unknown [1.2.752.24.3.3.25.7]

Implementation Version: WIMWLSCP_20_1

Maximum PDU Length:     28672

Async Ops Invoked:      1

Async Ops Performed:    1

Presentation Contexts:  1

  Presentation Context:  1 [Accept]

       Abstract Syntax:  Modality Worklist Information Model - FIND

       Transfer Syntax:  Implicit VR Little Endian: Default Transfer Syntax for 
DICOM 

2019-02-09 09:49:01.7580 INFO Dicom.Log.NLogManager+NLogger.Log TEST_01WL -> C-Find request [2] 

2019-02-09 09:49:01.8240 INFO Dicom.Log.NLogManager+NLogger.Log TEST_01WL <- C-Find response [2]: Optional Keys Not Supported 

2019-02-09 09:49:01.8240 INFO Dicom.Log.NLogManager+NLogger.Log TEST_01WL <- C-Find response [2]: Optional Keys Not Supported 

2019-02-09 09:49:01.8240 INFO Dicom.Log.NLogManager+NLogger.Log TEST_01WL <- C-Find response [2]: Optional Keys Not Supported 

2019-02-09 09:49:01.8240 INFO Dicom.Log.NLogManager+NLogger.Log TEST_01WL <- C-Find response [2]: Optional Keys Not Supported 

2019-02-09 09:49:01.8240 INFO Dicom.Log.NLogManager+NLogger.Log TEST_01WL <- C-Find response [2]: Optional Keys Not Supported 

2019-02-09 09:49:01.8240 INFO Dicom.Log.NLogManager+NLogger.Log TEST_01WL <- C-Find response [2]: Success 

2019-02-09 09:49:01.8830 INFO Dicom.Log.NLogManager+NLogger.Log TEST_01WL -> Association release request 

2019-02-09 09:49:01.8830 INFO Dicom.Log.NLogManager+NLogger.Log TEST_01WL <- Association release response 

2019-02-09 09:49:01.8830 INFO Dicom.Log.NLogManager+NLogger.Log Connection closed 

Ответы [ 2 ]

0 голосов
/ 11 февраля 2019

Просто добавьте, что означает статус: он сообщает, что в вашем запросе указаны совпадающие ключи, которые не были поддержаны Worklist-SCP.Это означает, что вы можете получить записи рабочего списка в ответе, которые не соответствуют критериям вашего запроса и должны были быть отфильтрованы SCP.

0 голосов
/ 11 февраля 2019

Итак, я решил, что «дополнительные ключи не поддерживаются» - это информационное сообщение, и данные фактически получены.

        request.OnResponseReceived += (req, rp) =>
        {
            if (rp.HasDataset)
            {
                dslist.Add(rp.Dataset);
            }

            if (rp.Status != DicomStatus.Pending && rp.Status != DicomStatus.QueryRetrieveOptionalKeysNotSupported)
            {                    
                return;
            }              
        };
...