Programing 11

[.NET Core] 3. Web API DB 연결 (Dapper)

이전글: [.NET Core] 2. Web API MiddleWare 구성 이전글: [.NET Core] 1. Web API 프로젝트 생성 1. 프로젝트생성 API 프로젝트 생성을 위해 ASP.NET Core 웹 응용 프로그램을 선택한다. 2.구성설정 Core 버전과 세부 프로젝트 구성을 설정할수있다. API 프로 tjddnjs625.tistory.com 먼저 Web API 에 Dapper로 DB연결을 하기위해 Nuget 패키지 관리자에서 Dapper 를 추가해준다. appsettings.json 파일에 connection string 을 정의하고 연결 문자열에 액세스할 수 있게 SqlConnection 개체를 반환하는 CreateConnection 메서드를 DapperContext 에 만든다. apps..

[.NET Core] 2. Web API MiddleWare 구성

이전글: [.NET Core] 1. Web API 프로젝트 생성 1. 프로젝트생성 API 프로젝트 생성을 위해 ASP.NET Core 웹 응용 프로그램을 선택한다. 2.구성설정 Core 버전과 세부 프로젝트 구성을 설정할수있다. API 프로젝트 뿐만아니라 일반적인 웹응용프로그 tjddnjs625.tistory.com 해당 프로젝트는 API 프로젝트로 사용할 예정이기 때문에 MiddelWare 를 구성하여 API Key 값에 대한 유효성 검사를 진행한다. APIKey 값을 appsettings.json 파일에 정의해두고 입력받은 헤더 값을 비교하여 결과를 리턴하기위해 먼저 위와 같이 폴더와 클래스 파일을 생성해주고 아래와 같은 코드를 작성한다 appsettings.json { "Logging": { "Lo..

[.NET Core] 1. Web API 프로젝트 생성

1. 프로젝트생성 API 프로젝트 생성을 위해 ASP.NET Core 웹 응용 프로그램을 선택한다. 2.구성설정 Core 버전과 세부 프로젝트 구성을 설정할수있다. API 프로젝트 뿐만아니라 일반적인 웹응용프로그램으로도설정이 가능하다. 버전은 2.2를 사용할예정이며 인증은 별도로 MiddleWare를 사용하여 검사할 예정이므로 별도의 설정없이 생성한다 확인버튼을 누르면 아래와같은 디렉토리 구조로 프로젝트가 생성된다. Startup.cs 기존 .NET 프레임워크의 Global.asax와 같다. 이름에서 알 수 있듯이 응용 프로그램이 시작될 때 가장 먼저 실행된다. 참고 : https://www.tutorialsteacher.com/core/aspnet-core-startup Startup ASP.NET C..

[C#] Azure BlobStorage 파일 업로드

NuGet 패키지 관리자에서 Widows.Azure.Storage 참조 추가 Azure Portal Blob Storage 에서 Storage account 및 accesskey 확인 private void blobStorageUpload(Stream stream, string fileName) { String accountname = "스토리지 계정"; String accesskey = "엑세스 키"; StorageCredentials creden = new StorageCredentials(accountname, accesskey); CloudStorageAccount acc = new CloudStorageAccount(creden, useHttps: true); CloudBlobClient cli..

Programing/.NET 2021.11.11

[C#] BarcodeLib 바코드 생성

NuGet 패키지 관리자에서 BarCodeLib 참조 추가 https://github.com/barnhill/barcodelib GitHub - barnhill/barcodelib: C# Barcode Image Generation Library C# Barcode Image Generation Library. Contribute to barnhill/barcodelib development by creating an account on GitHub. github.com 바코드 생성후 이미지 파일로 저장 public static void GetBarcode(int height, int width, BarcodeLib.TYPE type, string code, out System.Drawing.Image ..

Programing/.NET 2021.11.10

[C#]SFTP 파일 업로드

SFTP(Secure File transfer protocol) - SSH와 마찬가지로 전송시 암호화시켜서 전송을 하게 되는데 그 중에 FTP와 같이 파일을 전송할 때 암호화 시켜서 전송합니다. SSH에 부가적으로 있는 기능들 중 하나의 기능입니다. FTP와 같은 역할을 하지만, 사용하는 포트는 FTP 포트(기본 21포트) 가 아닌 SSH 접속시 사용하는 포트를 사용하고, SSH 접속 계정으로 로그인 할 수 있는 FTP 입니다. SFTP 장점 SFTP는 하나의 연결만 필요하며 데이터 연결이 필요하지 않다. 연결이 안전하게 보호된다. 프로토콜에서 제공하는 추가 기능에는 파일 잠금, 속성 조적, 권한 작업 및 더 많은 기능이 포함된다. SFTP 단점 SSH 키의 유효성 검사 및 관리는 더복잡하다 여러 공급업..

Programing/.NET 2021.11.08

[C#] AES256(AES/CBC/PKCS5Padding) 암/복호화

.NET 에서 AES256(AES/CBC/PKCS5Padding) 방식으로 암호화 복호화하는 방식이다. 1. HexString 방식의 Key / IV생성 using System; using System.Web; using System.IO; using System.Security.Cryptography; using System.Text; using Newtonsoft.Json.Serialization; using System.Collections.Generic; using System.Reflection; namespace Study.Model { public sealed class Crypto { ... //Key / Iv 생성 public static void GenerateKeyAndIV() { /..

Programing/.NET 2021.03.14

[C#] RestSharp 으로 HTTP/HTTPS 통신

RestSharp 은 .NET 에서 가장 많이 사용되고있는 REST API 클라이언트 라이브러리로 프로젝트에서 사용하기위해선 먼저 NuGet 패키지를 추가해준다. 사용방법 1. public ActionResult CallAPI() { responseDto res = new responseDto(); //호출결과를 받을 DTO string URL = "URL호출주소"; //URL호출주소 Dictionary param = new Dictionary(); param.Add("변수명1", "값1"); param.Add("변수명2", "값2"); res = JsonConvert.DeserializeObject(RestSharp_Post(URL,param)); } public dynamic RestSharp_Pos..

Programing/.NET 2020.07.24

[C#] Log파일 생성

지정경로에 폴더 및 파일이 없을 경우 파일을 생성하며 .txt 파일로 로그를 생성하는 코드입니다. public void LogWrite(string fileName, string msg) { string FilePath = "D:\\Logs\\" + fileName + "_" + DateTime.Today.ToString("yyyyMMdd") + ".txt"; string DirPath = "D:\\Logs\\"; string str = string.Empty; DirectoryInfo di = new DirectoryInfo(DirPath); FileInfo fi = new FileInfo(FilePath); try { if (di.Exists != true) Directory.CreateDirecto..

Programing/.NET 2019.07.30

[C#]EUC-KR UTF8변환

API 통신을할때 언어셋이 다른경우 한글이 깨져서 나오는경우가 발생한다. 그때 EUC-KR 에서 UTF8로 변환하는 코드이다. URL인코딩을 한경우 HttpUtility.UrlDecode() 메소드를 통해디코딩할때 Encoding.GetEncoding(51949) 메소드를 이용하여 EUC-KR 문자로 디코딩후 해당문자를 byte에담아 문자를 출력한다. int euckrCodepage = 51949; //EUC-KR 의 코드번호 // URL Encoding된 문자열을 Decoding name = HttpUtility.UrlDecode(HttpUtility.UrlDecode(name, Encoding.GetEncoding(euckrCodepage))); System.Text.Encoding euckr = S..

Programing/.NET 2018.08.01