Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 206. JNBridgePro와 한글 인코딩 문제 [링크 복사], [링크+제목 복사],
조회: 22311
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일

JNBridgePro와 한글 인코딩 문제

지난번 글에서 JNBridgePro 사용법을 알아봤는데요.

JNBridgePro를 이용해 C#에서 Java메서드 호출 테스트
; https://www.sysnet.pe.kr/2/0/1552

동료에게 Java의 인코딩 관련한 내용을 듣고서 간단하게 문제를 다시 테스트해 보았습니다.

이를 위해 파일을 읽는 소스코드를 만들고,

import java.io.*;

public class testC
{
    public void WriteText(String filePath) throws Exception 
    {
        File file = new File(filePath);
        FileInputStream fis = new FileInputStream(file);

        byte [] contents = new byte[4096];
        int readLength = fis.read(contents, 0, contents.length);
        fis.close();
        
        String txt = new String(contents, 0, readLength);
        System.out.println(txt);
    }   
}

이클립스에서 프로젝트 설정을 UTF-8로 설정한 후,

jnb_enc_test_1.png

컴파일 된 .class 파일을 얻어냈습니다. 이제 "JNBProxy v7.1 proxy generation tool (.NET 4.0-targeted)"를 실행해 "Project" / "Edit Classpath..." 메뉴로 .class 파일이 있는 폴더를 선택하고,

jnb_enc_test_2.png

이어서 "Project" / "Add Classes from Classpath..." 메뉴를 통해 위의 예제로 만들었던 클래스의 전체 이름을 (패키지가 없으니 단순하게) "testC"로 입력해 줍니다.

jnb_enc_test_3.png

패키지 명이 없으니, "Environment" 트리에는 "<<default package>>" 항목으로 나오고 이를 "Add =>" 버튼으로 "Exposed Proxies" 트리로 추가한 다음 역시 "<<default package>>" 항목을 선택한 후 "Project" / "Build..." 메뉴를 선택해 주면 .NET에서 사용할 수 있는 proxy dll 어셈블리 파일이 생성됩니다.

jnb_enc_test_4.png




프록시 생성을 마치고 예제 C# 프로젝트를 만들어 다음의 4개 파일을 "Add as Link"로 추가하고 "Copy to Output Directory" 옵션을 "Copy if newer"로 설정한 다음,

  • bcel-5.1-jnbridge.jar
  • jnbcore.jar
  • rlm932_x86.dll
  • testC.class

JNB 관련 어셈블리와 proxy dll을 참조 추가하고,

  • JNBShare.dll
  • JNBSharedMem_x86.dll
  • EncTest.dll

app.config 설정까지 완료해 줍니다.

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  
  <configSections>
    <sectionGroup name="jnbridge">
      <section name="dotNetToJavaConfig" 
                  type="System.Configuration.SingleTagSectionHandler, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"/>
    </sectionGroup>
  </configSections>
  
  <jnbridge>
    <dotNetToJavaConfig scheme="sharedmem" 
                        jvm="C:\Program Files (x86)\Java\jre7\bin\client\jvm.dll" 
                        jnbcore="jnbcore.jar"
                        bcel="bcel-5.1-jnbridge.jar" 
                        classpath=".\"/>
  </jnbridge>

</configuration>

마지막으로 C#에서 자바 클래스를 호출해주면 되겠지요? ^^

class Program
{
    static void Main(string[] args)
    {
        testC tc = new testC();
        tc.WriteText("test.json");
    }
}




테스트를 위해 test.json 파일을 Visual Studio에서 열어 "Unicode (UTF-8 without signature) - Codepage 65001"로 인코딩 옵션을 변경해 저장한 후 C# 프로그램을 호출하면 어떻게 될까요?

이클립스에서는 위와 같은 경우에 정상적으로 test.json 파일에 포함된 '한글' 내용을 출력할 수 있지만 JNBridgePro를 통해 생성된 proxy dll을 경유해 C#에서 호출하게 되면 UTF-8 형식의 파일을 읽어들이지 못합니다.

jnb_enc_test_5.png

하지만 test.json 파일을 시스템 디폴트 인코딩 타입이 적용되도록 ANSI로 저장하면 출력이 정상적으로 나옵니다.

jnb_enc_test_6.png

즉, 이클립스에서 UTF-8 인코딩 설정을 한 것이 C# 응용 프로그램 실행에서는 무관하게 동작을 한 것입니다. 이로써 문제는 파악되었지만 자바 라이브러리를 사용하려는 입장에서는 딱히 해결 방법이 없으니 아쉽게 되었습니다. 결국 이 문제를 제대로 해결하려면 사용하려는 java 라이브러리 측에서 BOM을 인식해 동작하는 코드를 만들어 주어야만 가능하다는 이야기가 됩니다.

역시 이번 글에 대한 테스트 코드도 첨부합니다. ^^




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







[최초 등록일: ]
[최종 수정일: 6/27/2021]

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

비밀번호

댓글 작성자
 




... 106  [107]  108  109  110  111  112  113  114  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11249정성태7/12/201718523오류 유형: 410. LoadLibrary("[...].dll") failed - The specified procedure could not be found.
11248정성태7/12/201725029오류 유형: 409. pip install pefile - 'cp949' codec can't decode byte 0xe2 in position 208687: illegal multibyte sequence
11247정성태7/12/201719357오류 유형: 408. SqlConnection 객체 생성 시 무한 대기 문제파일 다운로드1
11246정성태7/11/201718129VS.NET IDE: 118. Visual Studio - 다중 폴더에 포함된 파일들에 대한 "Copy to Output Directory"를 한 번에 설정하는 방법
11245정성태7/10/201723749개발 환경 구성: 321. Visual Studio Emulator for Android 소개 [2]
11244정성태7/10/201723306오류 유형: 407. Visual Studio에서 ASP.NET Core 실행할 때 dotnet.exe 프로세스의 -532462766 오류 발생 [1]
11243정성태7/10/201719992.NET Framework: 666. dotnet.exe - 윈도우 운영체제에서의 .NET Core 버전 찾기 규칙
11242정성태7/8/201720270제니퍼 .NET: 27. 제니퍼 닷넷 적용 사례 (7) - 노후된 스토리지 장비로 인한 웹 서비스 Hang (멈춤) 현상
11241정성태7/8/201719021오류 유형: 406. Xamarin 빌드 에러 XA5209, APT0000
11240정성태7/7/201721942.NET Framework: 665. ClickOnce를 웹 브라우저를 이용하지 않고 쿼리 문자열을 전달하면서 실행하는 방법 [3]파일 다운로드1
11239정성태7/6/201723411.NET Framework: 664. Protocol Handler - 웹 브라우저에서 데스크톱 응용 프로그램을 실행하는 방법 [5]파일 다운로드1
11238정성태7/6/201720931오류 유형: 405. NT 서비스 시작 시 "Error 1067: The process terminated unexpectedly." 오류 발생 [2]
11237정성태7/5/201722586.NET Framework: 663. C# - PDB 파일 경로를 PE 파일로부터 얻는 방법파일 다운로드1
11236정성태7/4/201725821.NET Framework: 662. C# - VHD/VHDX 가상 디스크를 마운트하지 않고 파일을 복사하는 방법파일 다운로드1
11235정성태6/29/201719961Math: 20. Matlab/Octave로 Gram-Schmidt 정규 직교 집합 구하는 방법
11234정성태6/29/201717302오류 유형: 404. SharePoint 2013 설치 과정에서 "The username is invalid The account must be a valid domain account" 오류 발생
11233정성태6/28/201717208오류 유형: 403. SharePoint Server 2013을 Windows Server 2016에 설치할 때 .NET 4.5 설치 오류 발생
11232정성태6/28/201718217Windows: 144. Windows Server 2016에 Windows Identity Extensions을 설치하는 방법
11231정성태6/28/201718836디버깅 기술: 86. windbg의 mscordacwks DLL 로드 문제 - 세 번째 이야기 [1]
11230정성태6/28/201718016제니퍼 .NET: 26. 제니퍼 닷넷 적용 사례 (6) - 잦은 Recycle 문제
11229정성태6/27/201719240오류 유형: 402. Windows Server Backup 관리 콘솔이 없어진 경우
11228정성태6/26/201716716개발 환경 구성: 320. Visual Basic .NET 프로젝트에서 내장 Manifest 자원을 EXE 파일로부터 제거하는 방법파일 다운로드1
11227정성태6/19/201724456개발 환경 구성: 319. windbg에서 python 스크립트 실행하는 방법 - pykd [6]
11226정성태6/19/201716327오류 유형: 401. Microsoft Edge를 실행했는데 입력 반응이 없는 경우
11225정성태6/19/201715629오류 유형: 400. Outlook - The required file ExSec32.dll cannot be found in your path. Install Microsoft Outlook again.
11224정성태6/13/201718128.NET Framework: 661. Json.NET의 DeserializeObject 수행 시 속성 이름을 동적으로 바꾸는 방법파일 다운로드1
... 106  [107]  108  109  110  111  112  113  114  115  116  117  118  119  120  ...