Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 10개 있습니다.)

C# - 간단하게 만들어 보는 리눅스의 nc(netcat), json_pp 프로그램

리눅스 도구에 보면 nc가 있는데,

nc - Unix, Linux Command
; https://www.tutorialspoint.com/unix_commands/nc.htm

윈도우에는 없군요. ^^ 검색해 보면 다음의 링크가 있지만,

netcat
; https://eternallybored.org/misc/netcat/

$ sudo apt install netcat

그래도 기본적인 기능이라면 C#으로 다음과 같이 쉽게 만들 수 있습니다.

using System;
using System.IO;
using System.Net;
using System.Net.Sockets;

namespace netcat
{
    class Program
    {
        static void Main(string[] args)
        {
            if (args.Length != 2)
            {
                return;
            }

            if (Console.IsInputRedirected == false)
            {
                Console.WriteLine("No input redirected");
                return;
            }

            int port = int.Parse(args[1]);

            using (TcpClient client = new TcpClient(args[0], port))
            {
                using (NetworkStream ns = client.GetStream())
                using (BinaryReader br = new BinaryReader(Console.OpenStandardInput()))
                {
                    while (true)
                    {
                        byte[] buffer = br.ReadBytes(512);
                        if (buffer == null || buffer.Length == 0)
                        {
                            break;
                        }

                        ns.Write(buffer, 0, buffer.Length);
                    }
                }
            }
        }
    }
}

빌드한 후 이런 식으로 테스트할 수 있고,

C:\temp> echo "Hello!" | netcat localhost 9900

C:\temp> type data.txt | netcat localhost 9900

그럼 pipeline으로 연결된 "Hello!" 문자열을, 그리고 "data.txt" 파일의 내용을 netcat이 전달받아 "localhost:9900" TCP 서버에 전송합니다.




유사하게 json_pp도 만들 수 있습니다. 주요 작업은 Newtonsoft.Json 패키지가 다 해주므로 다음과 같이 간단하게 코딩할 수 있습니다.

using Newtonsoft.Json;
using System;
using System.IO;

namespace json_pp
{
    class Program
    {
        static void Main(string[] args)
        {
            if (BclExtension.ConsoleHelper.IsInputHandleRedirected() == false)
            {
                Console.WriteLine("No input redirected");
                Help();
                return;
            }

            bool verbose = false;

            if (args.Length == 1 && args[0] == "-v")
            {
                verbose = true;
            }

            using (MemoryStream ms = new MemoryStream())
            using (BinaryReader br = new BinaryReader(Console.OpenStandardInput()))
            {
                while (true)
                {
                    byte[] buffer = br.ReadBytes(512);
                    if (buffer == null || buffer.Length == 0)
                    {
                        break;
                    }

                    ms.Write(buffer, 0, buffer.Length);
                }

                ms.Position = 0;
                using (StreamReader sr = new StreamReader(ms))
                using (StringWriter sw = new StringWriter())
                {
                    string text = sr.ReadToEnd();

                    if (verbose == true)
                    {
                        Console.WriteLine(text);
                    }

                    using (StringReader textReader = new StringReader(text))
                    {
                        Newtonsoft.Json.JsonTextReader jtr = new Newtonsoft.Json.JsonTextReader(textReader);
                        var jsonWriter = new JsonTextWriter(sw) { Formatting = Formatting.Indented };
                        jsonWriter.WriteToken(jtr);
                        Console.WriteLine(sw.ToString());
                    }
                }
            }
        }

        private static void Help()
        {
            string appName = Path.GetFileNameWithoutExtension(typeof(Program).Assembly.Location);
            Console.WriteLine($"(redirect_source) | {appName} [-v]");
            Console.WriteLine($"ex:");
            Console.WriteLine("\techo \"{ \\\"foo\\\": 500 }\" | " + appName);
        }
    }
}




Github에도 소스 코드 및 빌드된 바이너리를 올려두었습니다.

stjeong / Utilities / netcat
; https://github.com/stjeong/Utilities/tree/master/netcat

stjeong / Utilities / json_pp
; https://github.com/stjeong/Utilities/tree/master/json_pp

Utilities.zip
; https://github.com/stjeong/Utilities/releases




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 1/20/2023]

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

비밀번호

댓글 작성자
 



2023-02-10 11시50분
udp 모드로 접속하는 -u 옵션을 추가했고, TCP 서버로 단순히 listen하고 텍스트를 출력하는 -l 옵션을 추가했습니다.

// UDP 소켓으로 127.0.0.1:65300 측에 데이터 전달
c:\temp> echo "TEST" | netcat -u 127.0.0.1 65300

// 0.0.0.0:65300 바인딩의 TCP 서버
c:\temp> netcat -l 65300
정성태

... 46  47  48  49  50  51  52  53  54  55  [56]  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12576정성태3/25/202118778개발 환경 구성: 558. Docker Desktop for Windows에서 DockerDesktopVM 기반의 Kubernetes 구성 (2) - k8s 서비스 위치
12575정성태3/24/202117254개발 환경 구성: 557. Docker Desktop for Windows에서 DockerDesktopVM 기반의 Kubernetes 구성 [1]
12574정성태3/23/202122878.NET Framework: 1030. C# Socket의 Close/Shutdown 동작 (동기 모드)
12573정성태3/22/202120240개발 환경 구성: 556. WSL 인스턴스 초기 설정 명령어 [1]
12572정성태3/22/202119498.NET Framework: 1029. C# - GC 호출로 인한 메모리 압축(Compaction)을 확인하는 방법파일 다운로드1
12571정성태3/21/202117238오류 유형: 706. WSL 2 기반으로 "Enable Kubernetes" 활성화 시 초기화 실패 [1]
12570정성태3/19/202122987개발 환경 구성: 555. openssl - CA로부터 인증받은 새로운 인증서를 생성하는 방법
12569정성태3/18/202123178개발 환경 구성: 554. WSL 인스턴스 export/import 방법 및 단축 아이콘 설정 방법
12568정성태3/18/202116088오류 유형: 705. C# 빌드 - Couldn't process file ... due to its being in the Internet or Restricted zone or having the mark of the web on the file.
12567정성태3/17/202118782개발 환경 구성: 553. Docker Desktop for Windows를 위한 k8s 대시보드 활성화 [1]
12566정성태3/17/202118457개발 환경 구성: 552. Kubernetes - kube-apiserver와 REST API 통신하는 방법 (Docker Desktop for Windows 환경)
12565정성태3/17/202115091오류 유형: 704. curl.exe 실행 시 dll not found 오류
12564정성태3/16/202115954VS.NET IDE: 160. 새 프로젝트 창에 C++/CLI 프로젝트 템플릿이 없는 경우
12563정성태3/16/202118894개발 환경 구성: 551. C# - JIRA REST API 사용 정리 (3) jira-oauth-cli 도구를 이용한 키 관리
12562정성태3/15/202119399개발 환경 구성: 550. C# - JIRA REST API 사용 정리 (2) JIRA OAuth 토큰으로 API 사용하는 방법파일 다운로드1
12561정성태3/12/202118271VS.NET IDE: 159. Visual Studio에서 개행(\n, \r) 등의 제어 문자를 치환하는 방법 - 정규 표현식 사용
12560정성태3/11/202119486개발 환경 구성: 549. ssh-keygen으로 생성한 PKCS#1 개인키/공개키 파일을 각각 PKCS8/PEM 형식으로 변환하는 방법
12559정성태3/11/202119723.NET Framework: 1028. 닷넷 5 환경의 Web API에 OpenAPI 적용을 위한 NSwag 또는 Swashbuckle 패키지 사용 [2]파일 다운로드1
12558정성태3/10/202118915Windows: 192. Power Automate Desktop (Preview) 소개 - Bitvise SSH Client 제어 [1]
12557정성태3/10/202117044Windows: 191. 탐색기의 보안 탭에 있는 "Object name" 경로에 LEFT-TO-RIGHT EMBEDDING 제어 문자가 포함되는 문제
12556정성태3/9/202114759오류 유형: 703. PowerShell ISE의 Debug / Toggle Breakpoint 메뉴가 비활성 상태인 경우
12555정성태3/8/202118596Windows: 190. C# - 레지스트리에 등록된 DigitalProductId로부터 라이선스 키(Product Key)를 알아내는 방법파일 다운로드2
12554정성태3/8/202118045.NET Framework: 1027. 닷넷 응용 프로그램을 위한 PDB 옵션 - full, pdbonly, portable, embedded
12553정성태3/5/202117305개발 환경 구성: 548. 기존 .NET Framework 프로젝트를 .NET Core/5+ 용으로 변환해 주는 upgrade-assistant, try-convert 도구 소개 [4]
12552정성태3/5/202117179개발 환경 구성: 547. github workflow/actions에서 Visual Studio Marketplace 패키지 등록하는 방법
12551정성태3/5/202115751오류 유형: 702. 비주얼 스튜디오 - The 'CascadePackage' package did not load correctly. (2)
... 46  47  48  49  50  51  52  53  54  55  [56]  57  58  59  60  ...