즐겁게 개발을...

개발보다 게임이 더 많이 올라오는 것 같은...

개발/C# 37

[2022.09] Dapper 클래스 고도화

안녕하세요. 오늘은 기존에 올렸던 블로그의 클래스를 고도화해서 다시 올려봅니다. [2021.03] SqLite + Dapper(ORM) 사용방법 환경: Visual Studio 2017, C#, 닷넷 4.6.1 검색능력이 떨어진 건지 제대로 된 게시물이 없는 건지 국/내외 게시물을 다 뒤져도 안나와서 짜집기 + 자작으로 작성해보았다. Node.js에서 Squelize로 작년까지 endev.tistory.com 고도화 주제는 다음과 같습니다. 1. 인터페이스를 통해 클래스를 사용하는 위치에서 외부 참조를 사용하지 않게 한다. 2. 불특정 객체를 반환할 수 있도록 한다. 외부참조 사용하지 않게하기 IDBConnection은 범용적으로 모든 DB에서 인터페이스로 사용할 수 있습니다. 다만 DB별로 Connec..

개발/C# 2022.09.22

[2022.09] 비프 음을 Stop시킬 때까지 내게 하기

보통 오류 발생할 때 비프음을 넣을 때까지 많은데 이번 팁은 지속적으로 어떤 행위를 하고 있는 중에 지속적으로 비프음을 발생시킬 때까지 있습니다. 이때 사용하는 팁을 공유합니다. 제가 원하는 것은 삐~~~~~~~~~~~~~~~~~~~~~~~~~익인데, 삐삐삐삐삐삐삐삐삐삐삐삐삐삐삐삐 형태로 나옵니다. Duration을 길게 잡으면 되는데 이럴 경우 Beep함수에서 빠져나올 수가 없네요. 기본 제공되는 Beep클래스를 직접 구현한다면 가능할 것도 같습니다. 이것은 좀더 찾아보고 추가하겠습니다. 쓰레드 방식으로 구현한 다음 클래스를 추가합니다. public class BeepSound { private int _ToneHz; private int _gapMiliseconds; private bool _stop..

개발/C# 2022.09.21

[2022.09] 맥 어드레스를 이용한 라이선스 기법

단순한 맥어드레스를 이용한 라이선스를 프로그램에 적용시켜봅시다. 우선 클래스 투척합니다. public class LicGenerator { // base64 + Sha256 Hash public string CalculateHash(string rawData) { // Create a SHA256 using (SHA256 sha256Hash = SHA256.Create()) { // ComputeHash - returns byte array byte[] bytes = sha256Hash.ComputeHash(Encoding.UTF8.GetBytes(rawData)); // Convert byte array to a string StringBuilder builder = new StringBuilder()..

개발/C# 2022.09.20

[2022.09] Webhook API를 이용한 로깅기법

안녕하세요. 웹훅 API를 지원하는 도구 중 채널기반 메시징 도구인 메타모스트(Mattermost)를 이용해 C# 프로그램에서 발생하는 로그를 특정 채널로 수신할 수 있는 방법을 소개하겠습니다. 프로그램을 배포해서 어딘가에 구축하면 구축정보가 개발자에게 제대로 전달이 잘 안되는 경우가 있습니다. 제가 직접 배포 부터 구축까지 관리를 하는 상황이라면 체계를 만들어서 시키겠는데 그런 상황이 아니면 꽤나 답답하게 환경정보 없이 버그를 수정해야 하는 난감한 상황이 발생합니다. Mattermost로 소개하고 있지만 대신 로그 수신도구를 통해 통계나 대시보드로 활용할 수도 있고 별도 API서버를 통해 체계적으로 관리할 수도 있을 것 같네요. Gitlab과 Mattermost 연동하면서 갑자기 C#로그를 띄어보면 어..

개발/C# 2022.09.08

[2022.08] C# Dapper 불특정 테이블을 조회할 때

안녕하세요. 오랜만에 개발 관련 글을 적어봅니다. 오늘은 불특정 테이블을 조회할 때 C# 대표 ORM 라이브러리인 Dapper를 이용해 알려드리고자 합니다. (더 좋은 방법이 있다면 알려주세요) 특정 테이블이라면 Model클래스를 생성해서 타입지정해주면 알아서 IEnumerable으로 가져올 수 있습니다. 그런데 불특정 테이블이라면 클래스를 생성할 수 없으니 미리 그리드를 세팅할 수도 없고, 클래스도 생성할 수 없습니다. 코드와 주석을 함께 넣었습니다. Datatable dt = new Datatable(); SqlMapper.GridReader reader = Conn.QueryMultiple("SELECT * from table"); var readDatas = reader.Read(); // Dap..

개발/C# 2022.08.12
1 2 3 4 5 6 7 8