Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일

(시리즈 글이 3개 있습니다.)
닷넷: 2183. C# - eFriend Expert OCX 예제를 .NET Core/5+ Console App에서 사용하는 방법
; https://www.sysnet.pe.kr/2/0/13482

닷넷: 2186. 한국투자증권 KIS Developers OpenAPI의 C# 래퍼 버전 - eFriendOpenAPI NuGet 패키지
; https://www.sysnet.pe.kr/2/0/13498

닷넷: 2199. C# - 한국투자증권 KIS Developers OpenAPI의 WebSocket Ping, Pong 처리
; https://www.sysnet.pe.kr/2/0/13521




C# - eFriend Expert OCX 예제를 .NET Core/5+ Console App에서 사용하는 방법

예전에 eBEST나 키움 Open API를 실습해 봤으니,

eBEST XingAPI의 C# 래퍼 버전 - XingAPINet Nuget 패키지
; https://www.sysnet.pe.kr/2/0/12134

C# - 키움 Open API+ 사용 시 Registry 등록 없이 KHOpenAPI.ocx 사용하는 방법
; https://www.sysnet.pe.kr/2/0/12129

이번엔 ^^ 한국 투자 증권의 "eFriend Expert"를 실습해 보겠습니다.

(다른 것들도 모두 그랬듯이) 사이트에서 OpenAPI 신청하고 관련 설치 파일을 다운로드한 후 실행하면 되는데, 재미있게도 2가지 방식을 지원합니다.

  1. OCX를 이용한 방식
  2. Web API를 이용한 방식

Web API 방식은 보통 우리가 알고 있는 Open API 사용 체계를 따르기 때문에 기존의 ActiveX 문제로부터 완전히 자유로운 방식입니다. 따라서, eBEST보다 훨씬 더 나은 개발 환경을 제공하게 됩니다.

그런데, 일단 오늘은 1번 방식만 ^^ 살펴보겠습니다. 이에 대해서는 배포하는 문서인 expert_manual.pdf 파일을 보면 대충 감을 잡을 수 있는데요, 기존의 다른 OCX 기반의 통신 체계와 유사합니다. eBEST와 약간 다른 점이 있다면, 우리가 만든 프로그램을 단독으로 실행해서는 안 되고, 업체 측에서 제공한 "eFriend Expert" 프로그램을 실행한 후 거기서 뜬 UI 창을 통해 미리 로그인을 해 둬야 한다는 점입니다. (사실, eBEST도 백그라운드에서는 업체 측의 프로그램이 떴던 걸로 기억납니다.)

그다음은 우리가 만든 프로그램을 (관리자 권한으로) 실행해야 하는 식인데요, 그럼 내부의 업체 측에서 제공한 OCX 컨트롤을 통해 "eFriend Expert"와 통신하면서 데이터를 주고받는 듯합니다. 즉, 실제 통신은 "eFriend Expert"가 하고 OCX는 단지 대행만 하는 식입니다. (자세하게 확인은 안 해봤습니다. 그럴 것이다...라는 가정입니다.)

플랫폼도 다른 것과 마찬가지로 x86만 지원합니다.




다양한 언어로 된 예제도 함께 배포하고 있는데요, C# 예제도 있습니다. ^^ 그래서 Visual Studio에서 로딩해 곧바로 F5 키를 눌러 테스트할 수 있는 상황이어서 금방 분위기를 알 수 있게 됩니다.

자, 그럼 저는 동일한 코드를 만들자니 반복 작업에 불과하므로, 약간 색다르게 Console App으로 한번 ^^ 만들어 보겠습니다. 아마도 OCX의 동작을 보장하기 위해 Message Loop가 있어야 할 테니, 예전에 만들어 둔 코드로,

C# - Console 응용 프로그램에서 UI 스레드 구현 방법
; https://www.sysnet.pe.kr/2/0/12139

콘솔 동작을 테스트해 보겠습니다. 간단하게 Console App을 만들고, expert_CS_Sample.zip의 압축을 풀어 나온 ExpertTest 프로젝트의 빌드 디렉터리로부터 다음의 2개 파일을 복사해 참조를 추가합니다. (혹은, ActiveX OCX 파일을 참조 추가해도 되는데, 결국 그것도 아래의 2개 파일을 참조하는 것과 같습니다.)

  • AxInterop.ITGExpertCtlLib.dll
  • Interop.ITGExpertCtlLib.dll

코드는, 편의상 NuGet으로부터 CustomMessageLoop 패키지 참조 추가를 한 다음,

Install-Package CustomMessageLoop

프로젝트 설정을 다음과 같이 바꿔줍니다. (아래의 콘솔 프로젝트는 .NET 5를 대상으로 했지만, .NET 8까지 자유롭게 바꾸실 수 있습니다.)

<Project Sdk="Microsoft.NET.Sdk">

    <PropertyGroup>
        <OutputType>Exe</OutputType>

        <TargetFramework>net5.0-windows</TargetFramework>
        <Platform>x86</Platform>
        <UseWindowsForms>true</UseWindowsForms>
        <DisableWinExeOutputInference>true</DisableWinExeOutputInference>
        <Platforms>x86</Platforms>

    </PropertyGroup>

    <ItemGroup>
        <PackageReference Include="CustomMessageLoop" Version="1.0.8" />
    </ItemGroup>

    <ItemGroup>
        <Reference Include="AxInterop.ITGExpertCtlLib">
            <HintPath>..\Lib\AxInterop.ITGExpertCtlLib.dll</HintPath>
        </Reference>
        <Reference Include="Interop.ITGExpertCtlLib">
            <HintPath>..\Lib\Interop.ITGExpertCtlLib.dll</HintPath>
        </Reference>
    </ItemGroup>

</Project>

마지막으로, 계좌 번호만 확인하는 코드를 다음과 같이 테스트할 수 있습니다.

using CustomMessageLoop;
using System;
using System.Diagnostics;

namespace ConsoleApp1
{
    class Program
    {
        private AxITGExpertCtlLib.AxITGExpertCtl axTR1;

        [STAThread] // 반드시 Single-threaded apartment로 설정
        static void Main(string[] args)
        {
            Program pg = new Program();
            pg.Run();
        }

        private void Run()
        {
            using (MessageLoop mml = new MessageLoop())
            {
                mml.Loaded += Mml_Loaded;
                mml.Closed += Mml_Closed;

                mml.Run();

                while (true)
                {
                    string text = Console.ReadLine();
                    if (text == "q")
                    {
                        return;
                    }
                }
            }
        }

        private void Mml_Loaded(object sender, EventArgs e)
        {
            this.axTR1 = new AxITGExpertCtlLib.AxITGExpertCtl();
            this.axTR1.CreateControl();

            // 계좌 번호를 열거
            for (short i = 0; i < axTR1.GetAccountCount(); i++)
            {
                String Account = (String)axTR1.GetAccount(i);
                Console.WriteLine(Account);
            }

            bool isVTS = (bool)axTR1.IsVTS();

            if (isVTS == false)
            {
                Console.WriteLine("*** 주의 사항: 운영 접속입니다. ***");
            }
        }

        private void Mml_Closed(object sender, EventArgs e)
        {
        }
    }
}

끝입니다. ^^ 실행하면 DisableWinExeOutputInference 옵션으로 인해 Windows Forms 설정이지만 콘솔 창이 하나 뜨고, axTR1.GetAccount 메서드 호출로 반환받은 계좌 번호들이 출력되는 것을 확인할 수 있습니다.

특이하게 Login 과정이 없는데요, 앞서 언급한 대로 그것은 업체 측의 프로그램을 실행해 두면서 로그인을 직접 거치기 때문에 생략된 것입니다. 따라서, 코드에서는 로그인이 된 상황을 가정하고 로직을 완성해 나가면 됩니다.

첨부 파일은 위의 예제를 실습한 것으로, 마치 템플릿처럼 사용해도 좋을 것입니다. ^^




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 12/13/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2024-01-27 03시30분
expert_CS_Sample.zip의 압축을 풀었는데 아래 파일이 없네요. 다운로드할수 있는 방법이 있나요?
AxInterop.ITGExpertCtlLib.dll
Interop.ITGExpertCtlLib.dll
Duckmyung Joo
2024-01-27 08시24분
해당 파일의 압축을 풀었으면 그 상태 그대로 빌드하는 경우 2개의 DLL 파일이 출력 디렉터리에 생성될 것입니다. 아니면, 참조 관리자에서 "COM" 탭 영역에서 "ITGExpertCtl ActiveX 컨트롤 모듈"을 선택해 추가해도 됩니다.
정성태

... 16  17  18  19  20  21  22  23  24  25  26  27  [28]  29  30  ...
NoWriterDateCnt.TitleFile(s)
12930정성태1/19/20227042개발 환경 구성: 631. AKS/k8s의 Volume에 파일 복사하는 방법
12929정성태1/19/20226831개발 환경 구성: 630. AKS/k8s의 Pod에 Volume 연결하는 방법
12928정성태1/18/20226978개발 환경 구성: 629. AKS/Kubernetes에서 호스팅 중인 pod에 shell(/bin/bash)로 진입하는 방법
12927정성태1/18/20226743개발 환경 구성: 628. AKS 환경에 응용 프로그램 배포 방법
12926정성태1/17/20227228오류 유형: 787. AKS - pod 배포 시 ErrImagePull/ImagePullBackOff 오류
12925정성태1/17/20227326개발 환경 구성: 627. AKS의 준비 단계 - ACR(Azure Container Registry)에 docker 이미지 배포
12924정성태1/15/20228818.NET Framework: 1134. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 비디오 디코딩 예제(decode_video.c) [2]파일 다운로드1
12923정성태1/15/20227734개발 환경 구성: 626. ffmpeg.exe를 사용해 비디오 파일을 MPEG1 포맷으로 변경하는 방법
12922정성태1/14/20226801개발 환경 구성: 625. AKS - Azure Kubernetes Service 생성 및 SLO/SLA 변경 방법
12921정성태1/14/20225776개발 환경 구성: 624. Docker Desktop에서 별도 서버에 설치한 docker registry에 이미지 올리는 방법
12920정성태1/14/20226533오류 유형: 786. Camtasia - An error occurred with the camera: Failed to Add Video Sampler.
12919정성태1/13/20226343Windows: 199. Host Network Service (HNS)에 의해서 점유되는 포트
12918정성태1/13/20226588Linux: 47. WSL - shell script에서 설정한 환경 변수가 스크립트 실행 후 반영되지 않는 문제
12917정성태1/12/20225797오류 유형: 785. C# - The type or namespace name '...' could not be found (are you missing a using directive or an assembly reference?)
12916정성태1/12/20225525오류 유형: 784. TFS - One or more source control bindings for this solution are not valid and are listed below.
12915정성태1/11/20225805오류 유형: 783. Visual Studio - We didn't find any interpreters
12914정성태1/11/20227758VS.NET IDE: 172. 비주얼 스튜디오 2022의 파이선 개발 환경 지원
12913정성태1/11/20228270.NET Framework: 1133. C# - byte * (바이트 포인터)를 FileStream으로 쓰는 방법 [1]
12912정성태1/11/20228909개발 환경 구성: 623. ffmpeg.exe를 사용해 비디오 파일의 이미지를 PGM(Portable Gray Map) 파일 포맷으로 출력하는 방법 [1]
12911정성태1/11/20226218VS.NET IDE: 171. 비주얼 스튜디오 - 더 이상 만들 수 없는 "ASP.NET Core 3.1 Web Application (.NET Framework)" 프로젝트
12910정성태1/10/20226700제니퍼 .NET: 30. 제니퍼 닷넷 적용 사례 (8) - CPU high와 DB 쿼리 성능에 문제가 함께 있는 사이트
12909정성태1/10/20228101오류 유형: 782. Visual Studio 2022 설치 시 "Couldn't install Microsoft.VisualCpp.Redist.14.Latest"
12908정성태1/10/20225949.NET Framework: 1132. C# - ref/out 매개변수의 IL 코드 처리
12907정성태1/9/20226405오류 유형: 781. (youtube-dl.exe) 실행 시 "This app can't run on your PC" / "Access is denied." 오류 발생
12906정성태1/9/20227028.NET Framework: 1131. C# - 네임스페이스까지 동일한 타입을 2개의 DLL에서 제공하는 경우 충돌을 우회하는 방법 [1]파일 다운로드1
12905정성태1/8/20226685오류 유형: 780. Could not load file or assembly 'Microsoft.VisualStudio.TextTemplating.VSHost.15.0, Version=16.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a' or one of its dependencies.
... 16  17  18  19  20  21  22  23  24  25  26  27  [28]  29  30  ...