Development/C# 썸네일형 리스트형 Compress and Decompress Data Using GZipStream Introduction 이번시간에는 .Net Framework에서 제공하는 GZipStream을 이용해 간단하게 데이터를 압축하고 압축을 푸는 동작에 대해 소개합니다. GZipStream은 파일을 손실 없이 압축하거나 압축을 풀기 위해 사용되는 gzip 데이터 형식을 사용합니다. gzip 형식에 대한 자세한 내용은 RFC 1952, "GZIP file format specification 4.3"에서 확인 하실 수 있습니다. 참고로 GZip에서는 4GB이상의 파일 압축을 지원하지 않습니다. Compress/Decompress Extension Method 아래 코드는 BaseStream에 저장된 내용을 압축하거나, 압축을 푼뒤 결과를 OutputStream에 저장하는 Extension Method입니다... 더보기 Compute File Hash(MD5, SHA1, ETC..) Introduction 서버와 통신을 하는 Application 을 개발하다 보면, 필수적으로 사용자가 프로그램을 변조하였는지 확인해야 할 경우가 많습니다. 이 경우 일반적으로 프로그램이 실행될 때, 미리 서버에 등록해 놓은 HASH 값과 비교하여 변조 유무를 판단합니다. 아래 코드는 HASH 값을 추출하기 위한 Sample 코드입니다. Using the code using System.IO; using System.Security.Cryptography; public static class FileHashUtil { /// /// 파일로부터 MD5 Hash를 생성합니다. /// /// 파일 경로 /// MD5 Hash 문자열 public static string ComputeMD5Hash(string .. 더보기 Self Deleting Executables Introduction 자동 업데이트나, Installer/UnInstaller를 개발하다보면, 자기 프로세스를 삭제해야 하는경우가 있습니다. 강제로 삭제를 하려고 하면, 프로세스가 실행중이기 때문에 삭제가 불가능합니다. 이런경우 간단한 Batch(.bat)를 작성해서 해결 할 수 있습니다. 아래는 실행중인 프로세스를 종료하고 프로세스의 실행파일을 삭제하는 배치파일을 생성하는 기능을 제공하는 함수입니다. public static void SelfDelete() { Process CurrentProcess = Process.GetCurrentProcess(); string ExecuteFilePath = Assembly.GetCallingAssembly().Location; string BatchText .. 더보기 Load Assembly in Runtime using AppDomain Introduction Application을 개발할때 여러 프로젝트에서 동일한 기능을 공유하거나, 관리상의 목적으로 하여금 DLL 형태로 분리해 개발을 하는 경우가 있습니다. .Net으로 개발된 Application은 참조된 DLL(Assembly)을 로드할때 기본적으로 System32나, Application Root, GAC에 등록되어 있는 DLL을 검색하는데, 검색에 실패할경우 "FileNotFoundException"을 발생시킵니다. 만약, Application에서 참조하는 DLL(Assembly)의 경로가 위에서 언급한 위치와 다른 위치에 설치하고자 한다면 AppDomain을 이용해 런타임에 직접 Assembly를 Load하는 방식으로 해결 할 수 있습니다. What is AppDomain? .. 더보기 Simple Excel Provider Using OLEDB Introduction 일반적으로 엑셀 파일을 조작하기 위해서 Microsoft.Office.Interop.Excel 를 이용하지만, 이를 이용하기 위해서는 반드시 사용자의 컴퓨터에 엑셀이 설치되어 있어야 하며, 속도가 매우 느리다는 단점이 있습니다. 이번 강좌에서 소개할 내용은 OLEDB를 이용해 간단하게 엑셀파일을 읽고 쓰는 방법에 대해서 소개합니다. Excel Interop VS Excel OLEDB 본격적인 설명에 앞서 Interop을 이용한 엑셀 파일 조작과, OLEDB를 이용한 엑셀파일 조작의 차이에 대해 알아 보겠습니다. Excel Interop Excel Interop은 COM Interop을 이용해 엑셀 프로그램을 외부에서 제어하는 방식으로 동작합니다. Excel Introp 방식은 외부.. 더보기 이전 1 2 3 다음