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

C# - .NET Core 2.0 이하의 Unix Domain Socket 사용 시 System.IndexOutOfRangeException 오류

이전 글의 마지막에서,

C# - .NET Core Unix Domain Socket 사용 예제
; https://www.sysnet.pe.kr/2/0/11963

.NET Core 2.0 이하의 경우 다음에 공개된 UnixEndPoint 소스 코드를 사용하면 된다고 했는데요.

How to connect to a Unix Domain Socket in .NET Core in C#
; https://stackoverflow.com/questions/40195290/how-to-connect-to-a-unix-domain-socket-in-net-core-in-c-sharp

그 당시에는 사용할 일이 없다가 최근에 한 번 써봤는데 Accept 시에 ^^; 다음과 같은 예외가 발생합니다.

using (Socket clntSocket = _serverSocket.Accept())

/*
System.IndexOutOfRangeException: Index was outside the bounds of the array.
   at System.Net.Internals.SocketAddress.get_Item(Int32 offset)
   at System.Net.Sockets.IPEndPointExtensions.GetNetSocketAddress(SocketAddress address)
   at System.Net.Sockets.IPEndPointExtensions.Create(EndPoint thisObj, SocketAddress socketAddress)
   at System.Net.Sockets.Socket.Accept()
   at ConsoleApp1.Program.serverSockFunc(Object obj) in c:\temp\ConsoleApp1\ConsoleApp1\Program.cs:line 72
*/

에러를 없애려면 해당 소스 코드에서 2군데를 수정해야 합니다.

public UnixEndPoint(string filename)
{
    //if (filename == null)
    //    throw new ArgumentNullException("filename");

    //if (filename == "")
    //    throw new ArgumentException("Cannot be empty.", "filename");
    this.filename = filename;
}

public override SocketAddress Serialize()
{
    byte[] bytes = Encoding.Default.GetBytes(filename);
    SocketAddress sa = new SocketAddress(AddressFamily, 0x6c + 2);
    // sa [0] -> family low byte, sa [1] -> family high byte
    for (int i = 0; i < bytes.Length; i++)
        sa[2 + i] = bytes[i];

    //NULL suffix for non-abstract path
    sa[2 + bytes.Length] = 0;

    return sa;
}

이 중에서 0x6c가 나온 이유를 검색해 보니 다음과 같이 나오는군요. ^^

Why is the maximal path length allowed for unix-sockets on linux 108?
; https://stackoverflow.com/questions/34829600/why-is-the-maximal-path-length-allowed-for-unix-sockets-on-linux-108

수정한 전체 소스 코드는 다음의 github에 올려 두었습니다.

DotNetSamples/NetCore/UnixDomainSocketSample
; https://github.com/stjeong/DotNetSamples/tree/master/NetCore/UnixDomainSocketSample




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







[최초 등록일: ]
[최종 수정일: 8/1/2019]

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

비밀번호

댓글 작성자
 




... 91  [92]  93  94  95  96  97  98  99  100  101  102  103  104  105  ...
NoWriterDateCnt.TitleFile(s)
11728정성태10/9/201824532사물인터넷: 50. Audio Jack 커넥터의 IR 적외선 송신기 [1]
11727정성태10/8/201826065오류 유형: 491. Visual Studio의 리눅스 SSH 원격 연결 - "Connectivity Failure. Please make sure host name and port number are correct."
11726정성태10/7/201829264사물인터넷: 49. 라즈베리 파이를 이용해 원격 컴퓨터의 전원 스위치 제어파일 다운로드1
11724정성태10/5/201829168개발 환경 구성: 407. 유니코드와 한글 - "Hangul Compatibility Jamo"파일 다운로드1
11723정성태10/4/201820181개발 환경 구성: 406. "Docker for Windows" 컨테이너 내의 .NET Core 응용 프로그램에서 직렬 포트(Serial Port, COM Port) 사용 방법
11722정성태10/4/201825953.NET Framework: 798. C# - Hyper-V 가상 머신의 직렬 포트와 연결된 Named Pipe 간의 통신파일 다운로드1
11721정성태10/4/201826346.NET Framework: 797. Linux 환경의 .NET Core 응용 프로그램에서 직렬 포트(Serial Port, COM Port) 사용 방법파일 다운로드1
11720정성태10/4/201827750개발 환경 구성: 405. Hyper-V 가상 머신에서 직렬 포트(Serial Port, COM Port) 사용
11719정성태10/4/201828579.NET Framework: 796. C# - 인증서를 윈도우에 설치하는 방법
11718정성태10/4/201823343개발 환경 구성: 404. (opkg가 설치된) Synology NAS(DS216+II)에 cmake 설치
11717정성태10/3/201825045사물인터넷: 48. 넷두이노의 C# 네트워크 프로그램 [1]
11716정성태10/3/201826487사물인터넷: 47. Raspberry PI Zero (W)에 FTDI 장치 연결 후 C/C++로 DTR 제어파일 다운로드1
11715정성태10/3/201824163사물인터넷: 46. Raspberry PI Zero (W)에 docker 설치
11714정성태10/2/201824502사물인터넷: 45. Raspberry PI에 ping을 hostname으로 하는 방법
11713정성태10/2/201825239개발 환경 구성: 403. Synology NAS(DS216+II)에 docker 설치 후 .NET Core 2.1 응용 프로그램 실행하는 방법
11712정성태10/2/201831069.NET Framework: 795. C# - 폰트 목록을 한글이 아닌 영문으로 구하는 방법 [3]
11711정성태10/2/201825912오류 유형: 490. 윈도우 라이선스 키 입력 오류 0xc004f050, 0xc004e028
11710정성태10/2/201825551.NET Framework: 794. C# - 같은 모양, 다른 값의 한글 자음을 비교하는 호환 분해 [5]
11709정성태9/30/201824389개발 환경 구성: 402. .NET Core 콘솔 응용 프로그램을 docker로 실행/디버깅하는 방법 [1]
11708정성태9/30/201827667개발 환경 구성: 401. .NET Core 콘솔 응용 프로그램을 배포(publish) 시 docker image 자동 생성 [2]파일 다운로드1
11707정성태9/30/201829216오류 유형: 489. ASP.NET Core를 docker에서 실행 시 "Failed with a critical error." 오류 발생 [1]
11706정성태9/29/201823268개발 환경 구성: 400. Synology NAS(DS216+II)에서 실행한 gcc의 Segmentation fault [2]
11705정성태9/29/201823760개발 환경 구성: 399. Synology NAS(DS216+II)에 gcc 컴파일러 설치
11704정성태9/29/201829747기타: 73. Synology NAS 신호음(beep) 끄기 [1]파일 다운로드1
11703정성태9/27/201822475개발 환경 구성: 398. Blazor 환경 구성 후 빌드 속도가 너무 느리다면? [2]
11702정성태9/26/201820238사물인터넷: 44. 넷두이노(Netduino)의 네트워크 설정 방법
... 91  [92]  93  94  95  96  97  98  99  100  101  102  103  104  105  ...