- 浏览: 3416630 次
- 性别:
- 来自: 苏州
文章分类
最新评论
-
sonichy:
Qt5改动很多,要改改了。
基于QItemDelegate的例子1 SpinBoxDelegate -
我的主页6:
楼主,2.2子查询的分页方式:SELECT * FROM ar ...
Mysql 分页语句Limit用法 -
liguoqi:
非常感谢楼主的用心指导,工具以及图片例子都提供了 赞!
两款免费DCIOM 图像浏览软件介绍和DICOM图像例子供下载 -
liguoqi:
问下这个图片怎么解压损坏呀
两款免费DCIOM 图像浏览软件介绍和DICOM图像例子供下载 -
liguoqi:
楼主讲解的非常详细,还附带工具和图片例子,非常感谢
两款免费DCIOM 图像浏览软件介绍和DICOM图像例子供下载
就像DCMTK官方论坛说的那个问题一样:问题:自定义Appender输出DCMTK的oflog
DCMTK日志输出类
大家都知道:DCMTK只提供下面四个日志输出类。
FileAppender: Appends log events to a file.(将DCMTK日志输出到一个文件中)
ConsoleAppender:ConsoleAppender appends log events to STD_NAMESPACE cout
or STD_NAMESPACE cerr
using a layout specified by the user.(将DCMTK日志输出到控制台cmd)
log4cplus::NullAppender:Appends log events to ......(不输出,空的)
SocketAppender:Sends spi::InternalLoggingEvent objects to a remote a log server.(将该日志事件发送给远程服务器)
因为我需要在自己的Qt Gui项目中也输出DCMTK日志,供系统测试或者通过我项目的日志模块登记到数据库、文件中。总之我需要把DCMTK的日志模块集成到自己的Gui项目中。于是我自定义了一个GuiAppender类。
GuiAppender:
实现将DCMTK日志事件捕获,并将日志输出在VS2008的Debug窗口中,也可以后期供调用。
实现源码
我的GuiAppender类 源码
#ifndef GUIAPPENDER_H #define GUIAPPENDER_H #include "dcmtk/oflog/config.h" #include "dcmtk/oflog/appender.h" #include "dcmtk/oflog/helpers/property.h" #include <sstream> namespace log4cplus { class GuiAppender : public Appender { public: GuiAppender(); GuiAppender(const log4cplus::helpers::Properties& properties, log4cplus::tstring& error); virtual ~GuiAppender(); // Methods virtual void close(); protected: virtual void append(const log4cplus::spi::InternalLoggingEvent& event); //声明一个ostringsteam对象 STD_NAMESPACE ostringstream outString ; private: // Disallow copying of instances of this class GuiAppender(const GuiAppender&); GuiAppender& operator=(const GuiAppender&); }; } // end namespace log4cplus #endif // GUIAPPENDER_H
#include "GuiAppender.h" #include <string> #include <QDebug> #include <QString> log4cplus::GuiAppender::GuiAppender() { } log4cplus::GuiAppender::GuiAppender(const log4cplus::helpers::Properties& properties, tstring&) : Appender(properties) { } log4cplus::GuiAppender::~GuiAppender() { } void log4cplus::GuiAppender::close() { } // This method does not need to be locked since it is called by // doAppend() which performs the locking void log4cplus::GuiAppender::append(const spi::InternalLoggingEvent& event) { //格式化输入DCMTK日志 layout->formatAndAppend(outString, event); //获取DCMTK日志字符串流 STD_NAMESPACE string m = outString.str(); //将C++标准字符串流,转换成QString QString t = QString::fromStdString(m); //输出调试信息 qDebug() << t; //清空 outString.str(""); }
主程序测试。
/* * * Copyright (C) 2011-2012, OFFIS e.V. * All rights reserved. See COPYRIGHT file for details. * * This software and supporting documentation were developed by * * OFFIS e.V. * R&D Division Health * Escherweg 2 * D-26121 Oldenburg, Germany * * * Module: dcmnet * * Author: Michael Onken * * Purpose: Test for move feature of the DcmSCU class */ #include "dcmtk/config/osconfig.h" /* make sure OS specific configuration is included first */ #include "dcmtk/dcmnet/diutil.h" #include "DcmTestSCU.h" #include <QtGui/QApplication> #include <QDebug> #include "dcmtk/oflog/oflog.h" #include "GuiAppender.h" #define OFFIS_CONSOLE_APPLICATION "testscu" static OFLogger echoscuLogger = OFLog::getLogger("dcmtk.apps." OFFIS_CONSOLE_APPLICATION); static char rcsid[] = "$dcmtk: " OFFIS_CONSOLE_APPLICATION " v" OFFIS_DCMTK_VERSION " " OFFIS_DCMTK_RELEASEDATE " $"; // our application entity title used for calling the peer machine #define APPLICATIONTITLE "TEST-SCU" // host name of the peer machine "www.dicomserver.co.uk" #define PEERHOSTNAME "10.3.2.84" // TCP/IP port to connect to the peer machine "11112" #define PEERPORT 5104 // application entity title of the peer machine #define PEERAPPLICATIONTITLE "MOVESCP" // MOVE destination AE Title #define MOVEAPPLICATIONTITLE "TEST-SCU" #define QRResponse FINDResponse static Uint8 findUncompressedPC(const OFString& sopClass, DcmSCU& scu) { Uint8 pc; pc = scu.findPresentationContextID(sopClass, UID_LittleEndianExplicitTransferSyntax); if (pc == 0) pc = scu.findPresentationContextID(sopClass, UID_BigEndianExplicitTransferSyntax); if (pc == 0) pc = scu.findPresentationContextID(sopClass, UID_LittleEndianImplicitTransferSyntax); return pc; } // ******************************************** int main(int argc, char *argv[]) { QApplication a(argc, argv); /* Setup DICOM connection parameters */ OFLog::configure(OFLogger::DEBUG_LOG_LEVEL); OFLOG_DEBUG(echoscuLogger, "OFLOG_DEBUG"); /* specify log pattern */ OFauto_ptr<log4cplus::Layout> layout(new log4cplus::PatternLayout("%D{%Y-%m-%d %H:%M:%S.%q} %5p: %m%n")); //建立Gui日志输出类 log4cplus::SharedAppenderPtr guiAppender(new log4cplus::GuiAppender()); guiAppender->setLayout(layout); //获取全局日志对象 log4cplus::Logger log = log4cplus::Logger::getRoot(); //去除所有日志输出类 log.removeAllAppenders(); //加入Gui输出类 log.addAppender(guiAppender); //设置日志输出层 log.setLogLevel(OFLogger::INFO_LOG_LEVEL); //测试输出一个error日志 OFLOG_ERROR(log, "There are six log levels and each provides a OFLOG_level() macro"); //继续测试,输出DCMTK C-Echo动作产生的INFO //后面是DCMTK的DcmNet模块中 网络通信的测试,大家不需要了解 DcmTestSCU scu; // set AE titles scu.setAETitle(APPLICATIONTITLE); scu.setPeerHostName(PEERHOSTNAME); scu.setPeerPort(PEERPORT); scu.setPeerAETitle(PEERAPPLICATIONTITLE); // Use presentation context for FIND/MOVE in study root, propose all uncompressed transfer syntaxes OFList<OFString> ts; ts.push_back(UID_LittleEndianExplicitTransferSyntax); ts.push_back(UID_BigEndianExplicitTransferSyntax); ts.push_back(UID_LittleEndianImplicitTransferSyntax); scu.addPresentationContext(UID_FINDStudyRootQueryRetrieveInformationModel, ts); scu.addPresentationContext(UID_MOVEStudyRootQueryRetrieveInformationModel, ts); scu.addPresentationContext(UID_VerificationSOPClass, ts); /* Initialize network */ OFCondition result = scu.initNetwork(); if (result.bad()) { DCMNET_ERROR("Unable to set up the network: " << result.text()); return 1; } /* Negotiate Association */ result = scu.negotiateAssociation(); if (result.bad()) { DCMNET_ERROR("Unable to negotiate association: " << result.text()); return 1; } /* Let's look whether the server is listening: Assemble and send C-ECHO request */ result = scu.sendECHORequest(0); if (result.bad()) { DCMNET_ERROR("Could not process C-ECHO with the server: " << result.text()); return 1; } scu.closeAssociation(DCMSCU_RELEASE_ASSOCIATION); return a.exec(); }
实现结果
最终结果,将DCMTK日志输出到VS2008的Debug窗口中。
------------------------------------
柳北风儿
http://qimo601.iteye.com
------------------------------------
发表评论
-
DCMTK: DcmSCP, error:QueryRetrieveLevel larger remaining bytes
2012-11-06 09:48 2869最近在DcmSCU发送一个findRequest后,DcmSC ... -
DICOM标准(2011)
2012-10-22 10:31 2905DICOM标准(2011) 最新版,下载请看我的百度云网 ... -
DCMTK:wwwapp instalation
2012-10-18 15:55 3226问题 最近按照wwwapp.txt安装work ... -
workList in DCMTK问题总结
2012-10-17 19:37 3461最近正在配置DCMTK中的worklist,因为需要响应C-F ... -
web Server支持 perl
2012-10-17 10:06 3332最近使用DCMTK 安装worklist 需要用到webser ... -
DICOM C-GET vs C-MOVE
2012-10-08 17:01 6440DICOM中C-Get 和C-Move的区别。 C-Move ... -
【最新snapshot】DCMTK3.6.1(MD支持库)安装说明
2012-09-25 16:16 7268【前言】 最近,因为需要开发DICOM ... -
问题:自定义Appender输出DCMTK的oflog
2012-09-24 10:09 2733在我调试DCMTK的DcmNet过程中,发现在Oflog中,D ... -
DCMTK:Receiving Images from PACS using DCMSCU
2012-09-15 14:03 5081通过DCMTK的DCMSCU,从PACS获取图像,看看人 ... -
DCMTK: Set output directory to DcmSCP
2012-09-18 09:16 4477Author Message -
DCMTK:DCMSCU get series
2012-09-15 14:02 2717Author Message mano ... -
DCMTK DCMSCU例子
2012-09-15 14:01 5588转载:http://forum.dcmtk.org/viewt ... -
DCMTK DCMScu和DCMScp 细节讨论
2012-09-15 14:04 13539PACS connection Moderator: ... -
DCMTK Howto: User Identity Negotiation
2012-09-18 09:16 6125Howto: User Identity Negotia ... -
DCMTK:howto:dcmscu-example 网络客户端
2012-09-15 14:00 4274DcmSCU example program Th ... -
DCMTK Create a Mammography CAD SR Document
2012-09-18 09:17 2717Howto: Create a Mammography ... -
DCMTK create GSPS object with multiple image references
2012-09-18 09:17 2935Howto: Create GSPS object wi ... -
DCMTK提取Overlay Data
2012-09-14 14:07 4189Howto: Extract Overlay Data ... -
DCMTK获取压缩后的pixel data
2012-09-14 14:06 6292Howto: Accessing Compressed ... -
DCMTK读取多帧图像,不需要全部读取像素数据,即可处理数据
2012-09-14 14:06 5557Howto: Access multi-frame im ...
相关推荐
利用Log4net,可以更好的,统一的去管理众多的业务系统,了解并跟踪业务系统运行状况
前端日志工具库,简单的api,可以通过配置不同的 level 和 appender 来输出日志
log4j按照不同appender生成日志例子,log4j按照不同接口生成各自日志文件小例子。
打印日志的在程序中是必不可少的,如果需要将不同的日志打印到不同的地方,则需要定义不同的Appender,然后定义每一个Appender的日志级别、打印形式和日志的输出路径,下面看一个示例吧
logback日志写logstash配置appender参考
1 Log4J简介 3 2 Log4J实现 3 2.1 Log4J配置 3 2.2 Log4J的类图 4 2.3 日志级别 4 2.4 配置Logger组件 4 2.5 配置Appender组件 5 2.6 配置Layout组件 6 2.7 日志文件的名称 7 ...3.7 自定义Appender 10
主要介绍了spark通过kafka-appender指定日志输出到kafka引发的死锁,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
Log4J主要由三大组件构成:Logger:负责生成日志,并能够对日志信息进行分类筛选,通俗地讲就是决定什么日志信息应该输出,什么日志信息应该被忽略 Appender:定义了日志信息输出的目的地,指定日志信息应该被输出到...
logback+slf4j自定义appender输出的使用方法,让你明白什么是自定义输出意思使用方式。
log4j2 jdbc appender 实现将日志保存到 mysql。
#自定义Appender log4j.appender.im = net.cybercorlin.util.logger.appender.IMAppender log4j.appender.im.host = mail.cybercorlin.net log4j.appender.im.username = username log4j.appender.im.password = ...
水槽附加器 Flume appender 从一系列日志库(log4j、logback)推送日志事件
NULL 博文链接:https://improve.iteye.com/blog/1462030
Dynatrace通用日志提取Log4j2 Appender Log4j2 Appender将Java应用程序与Dynatrace通用日志提取功能集成在一起。 为了使其正常工作,您必须提供两个参数: activeGateUrl启用了通用日志提取模块的ActiveGate实例的...
那我们如果需要实现自定义的格式存储日志,该怎么办呢 ? 通过源码,我们可以发现,mars\log\src\appender.cc文件中的appender_open方法,会拼接下面这部分信息 ^^^^^^^^^^Feb 18 2020^^^10:19:18^^^^^^^^^^[24414,...
是基于日志级别的可自定义日志着色器,用于 。 与使用 关键字提供的内置颜色相比,此扩展名的可定制性要好得多。 适用于任何logback实现,例如 , 。 快速开始 将添加到项目的类路径中。 配置使用不同的日志级别的...
设置log4j的根目录,值为 日志等级(DEBUG,INFO,WARN,ERROR,FATAL) , 输出目标名称 log4j.rootLogger=DEBUG,A1 设置输出方式,常用的有: ConsoleAppender 在控制器中输出信息 RollingFileApperder 在文件中输出...
NULL 博文链接:https://1017401036.iteye.com/blog/2332210
输出日志文件 将日志信息存入数据库" Apache JCL "common log介绍 log中的接口" SLF4J "日志门面的使用 日志的绑定 日志的桥接 日志门面的原理" log-back "log-back的日志框架 log-back的配置 logback记录tomcat的...
ApplicationInsights.Log4Net 用于 Application Insights (Azure) 的 Log4Net Appender。 创建这个项目是因为 MSFT 项目目前不是开源的,我想添加更多功能。