博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
DICOM医学图像处理:WEB PACS初谈
阅读量:6213 次
发布时间:2019-06-21

本文共 5201 字,大约阅读时间需要 17 分钟。

背景:

        周末看到了一篇原公司同事的文章,讲的是关于新的互联网形势下的PACS系统。正好上一篇专栏文章也提到了有想搭建一个worklist服务器的冲动,所以就翻箱倒柜将原本学生时代做课题时搭建的简易Web PACS找了出来,借着再次搭建的机会学习一下Web PACS相关的技术,例如WADO标准、CGI或者FastCGI等技术。

WEB PACS技术浅谈:

        WEB PACS是一种利用互联网技术,跨越了医院和地域限制的,可随意查询和获取DICOM对象的PACS系统。目前常见的方式有两种:第一种是通过Web服务器提供查询定位,将对应DICOM影像存储服务器(通常为FTP)的地址与路径返回,客户端再向DICOM影像存储服务器请求对象;第二种是通过Web服务器统一提供查询及返回请求对象。两者各有利弊,第一种通过分别部署Web服务器和FTP文件服务器,减轻了Web服务器的负担,加快了响应时间,但是该方案也存在着诸多缺点,例如获取图像需要发送两次请求,FTP服务器安全性维护代价高,要求在浏览器下载能够解析DICOM图像的插件等等;第二种Web服务器整合了查询与返回,去除了FTP服务器,部署方便,它的缺点是由于Web服务器返回的数据是真实DCM转换过来的BMP或JPEG文件,因此某些依赖于DICOM文件其他信息的操作(例如窗宽窗位调整)需要重新请求服务端,要求更新数据,因此对服务器的处理能力消耗较大,对带宽也有一定要求。

两种方式的示意图如下:

(摘自文献《DICOM WADO原理及应用研究》)

1)WADO

        WADO(Web Access to DICOM Persistent Object),是DICOM标准中的一部分,提供了一种通过HTTP或HTTPS协议并利用DICOM的标识符从HTML页或XML文档中存取与重现DICOM对象的机制,用于解决在互联网环境下访问DICOM对象——这也可以认为是Web PACS的终极目标。与标准的基于HTTP或HTTPS的网络访问方式相同,用户在浏览器地址栏中输入URL,向服务器发送WEB请求,服务器接收到请求后根据URL中提供的参数,在服务端定位要求的图像或报告回送给浏览器,示意图如下(摘自DICOM标准第18章),

 

        其实WADO标准就是定义了客户端和服务端之间交互的规则,可以简单的理解为双向交互时的参数约定,即服务端可以根据浏览器端发送参数的不同来实现常见的单机版PACS的C-FIND、C-MOVE、C-STORE等功能。DICOM标准中关于WADO部分的介绍也主要是各种参数规则的说明,以及部分URL实例,这里截取一个来简单的说明一下:

 

        如上图所示,URL采用常见的GET方式,将传统的PACS系统客户端发送查询时的参数发送给服务端,例如studyUID、seriesUID和objectUID(其实就是DICOM图像中的SOP Instance UID)。

2)CGI

        CGI(Common Gateway Interface),是WWW技术中最重要的技术之一,有着不可取代的重要地位。CGI定义了外部应用程序(CGI程序)与Web服务器之间的接口标准,独立于开发语言,给用户提供了一种从网页浏览器向执行在服务器上的程序请求数据的方式——为Web PACS的实现提供了一种途径。

        为了理解CGI的含义,必须要搞清楚WEB开发中常见的前端和后端。前端就是Web应用中用户可以看得见碰的着的东西,服务端接收到请求后大多直接将数据传输到浏览器;后端更多的是用户看不到的(这里指的看不到不是操作后的结果看不到,而是操作的流程看不到),接收到请求后需要服务端进一步操作的,例如查询数据库、算法运算等等。而CGI就是实现这种由浏览器的输入触发在WEB服务器上运行的程序的标准。

实际环境搭建:

        正如博文第一部分所述,由于第一类Web PACS需要浏览器安装第三方插件,需要单独部署FTP服务器,因此在课题起初没有采用该方案。第二种Web PACS服务端在接受请求后会再向影像服务器发送请求,这正是上文中提到的CGI技术的一种很好的应用场景。下面就具体介绍一下如何搭建CGI应用环境:

1)WampServer+FastCGI

Web服务器搭建:

        WampServer安装包下载

        安装过程中有可能会遇到“缺少msvcr110.dll,程序无法启动”错误,可以参照中给出的方法解决,需要提醒的是下载的Visual C++ Redistributable for VisualStudio 2012 Update 4版本不是由电脑的操作系统类型(32位or64位)来决定,而是应该根据WampServer安装包的类型来选择。安装完Visual C++ Redistributable for VisualStudio 2012 Update 4后需要重新安装WampServer。

配置FastCGI环境:

参考和对Apache服务器进行配置。在配置完成后重启WampServer竟然失败,出现如下错误:

        更悲剧的是查看Apache的ErrorLog竟然没有提示,所以只能对修改的httpd.conf配置文件逐行排查,通过逐行注释的本方法最后找到了问题所在,由于修改DirectoryIndex引发的错误,恢复到原本的顺序后,重启WampServer竟然奇迹般的成功了,小有成就感啊,至于具体的原因后续在慢慢查找,确定了再补充上来。

2)C语言CGI实例

        配置完开发环境后,给出一个简单的测试,由于电脑中没有安装PHP,所以这里就讨巧一下,直接利用Apache自带的cgi来调用一下C语言开发的程序,关于C语言CGI的配置比较简单,在Apache目录下的modules中已经包含了cgi模块,只需要在httpd.conf配置文件中指定c-cgi运行的目录即可,添加如下代码:

 

ScriptAlias /cgi-bin/"C:/wamp/www/c-cgi/"AddHandler cgi-script .exe .pl .cgi
Options Indexes FollowSymLinks ExecCGIAllowOverride allOrder allow,denyAllow from allRequire local
        具体的配置可参考 ,实例的话就不要用该博文中的了,用我下面给出的完整示例。

 

GET方法实例源码

 

#include 
#include
int main(void){ char *data; char a[10],b[10]; printf("Content-Type:text/html\n\n"); printf("\n"); printf("\n
Get Method\n\n"); printf("\n"); printf("
\n"); data = getenv("QUERY_STRING"); if(data==NULL) return 1; if(sscanf(data,"a=%[^&]&b=%s",a,b)!=2){ printf("
Error parameters should be entered!
\n"); } else{ printf("
a + b = %d
\n",atoi(a)+atoi(b)); } printf("

"); printf("
"); printf("
\n"); printf("\n"); printf("\n"); return 0;}
利用VS编译后的可执行文件为gettest.exe,放到/www/cgitest-c目录下。

 

POST方法实例源码

 

#include 
#include
int main(void){ int len; char *lenstr,poststr[20]; char m[10],n[10]; printf("Content-Type:text/html\n\n"); printf("\n"); printf("\n
post Method\n\n"); printf("\n"); printf("
\n"); lenstr=getenv("CONTENT_LENGTH"); if(lenstr == NULL) printf("
Error parameters should be entered!
\n"); else{ len=atoi(lenstr); fgets(poststr,len+1,stdin); if(sscanf(poststr,"m=%[^&]&n=%s",m,n)!=2){ printf("
Error: Parameters are not right!
\n"); } else{ printf("
m * n = %d
\n",atoi(m)*atoi(n)); } } printf("

"); printf("
"); printf("
\n"); printf("\n"); printf("\n"); fflush(stdout); return 0;}
利用VS编译后的可执行文件为posttest.exe,同样放到/www/cgitest-c目录下。

 

测试网页源码

 

CGI Testing
Method: GET
please input two number:
+
=
Method: POST
please input two number:
*
=
放到Apache服务器根目录下,在浏览器中通过localhost/cgitest-c.html可以访问到。

 

实际运行结果

        上述通过一个简单的计算来演示了CGI技术的实现和开发流程,当然对于简单的数字计算WEB前端自己就搞定了,此处只是为了说明CGI流程。至此整个Web PACS的Web服务端就已经搭建的差不多了,利用CGI或FastCGI我们可以使用服务端的其他语言开发的程序来实现我们想要的功能,那么后续的工作就跟开发C/S模式的PACS一样了,用C/C++、C#或JAVA等高级语言开发PACS服务相关的程序供Web服务器调用即可。本博文中演示的是调用exe可执行文件,这种方式有风险,后续我会介绍在FastCGI模式下的利用PHP调用C++或C#或JAVA动态库的更安全的实现方式。

你可能感兴趣的文章
一条咸鱼的养成
查看>>
基于 Laravel 的在线点播系统 MeEdu v1.0 版本上线
查看>>
Go基础系列:struct和嵌套struct
查看>>
【nodejs】让nodejs像后端mvc框架(asp.net mvc )一样处理请求--路由限制及选择篇(2/8)【route】...
查看>>
WPFの阴影效果
查看>>
PostgreSQL 10.1 手册_部分 II. SQL 语言_第 14 章 性能提示_14.3. 用显式JOIN子句控制规划器...
查看>>
VS生成Cordova for Android应用之Gradle
查看>>
使用IB_DESIGNABLE与IBInspectable实现可在SB编辑border与corner的Button
查看>>
Android&Java面试题大全—金九银十面试必备
查看>>
普林斯顿大学算法公开课笔记——选择排序
查看>>
Hikyuu 1.1.2 发布,量化交易研究框架
查看>>
Android ADB命令的使用
查看>>
Python全栈 Web(Flask框架、CRUD、聚合分组)
查看>>
【最佳实践】使用BYOK密钥加密OSS中对象
查看>>
Scrapy实战-爬取豆瓣漫画
查看>>
[剑指offer] 矩阵中的路径
查看>>
log4j2配置
查看>>
07.Java基础(泛型)
查看>>
自制操作系统Antz day11——实现shell(下)命令响应
查看>>
MyBatis 笔记
查看>>