728x90

4.0 은 64비트에서 지원하지 않는다.

1. 빌드 속성을 바꿔도 된다면 프로젝트 빌드 속성에서 32비트로 바꾸면 해결된다.

2. 64 비트로 빌드해야한다면 아래 링크로 들어가 재배포 패키지를 설치한다.
https://www.microsoft.com/ko-kr/download/details.aspx?id=49318

그리고 코드에서 아래와 같이 연결 문자열을 변경한다.
기존
OleDbConnection conn = new OleDbConnection("Provider =Microsoft.Jet.OleDb.4.0;Persist Security Info=False;Jet OLEDB:Database Password=1234;Data Source=" + filePath);
변경
OleDbConnection conn = new OleDbConnection("Provider=Microsoft.ACE.OleDb.12.0;Persist Security Info=True;Jet OLEDB:Database Password=1234;Data Source=" + filePath);

 

참고
http://daplus.net/c-microsoft-jet-oledb-4-0-%EA%B3%B5%EA%B8%89%EC%9E%90%EA%B0%80-%EB%A1%9C%EC%BB%AC-%EC%BB%B4%ED%93%A8%ED%84%B0%EC%97%90-%EB%93%B1%EB%A1%9D%EB%90%98%EC%96%B4-%EC%9E%88%EC%A7%80-%EC%95%8A%EC%8A%B5/

 

[C#] Microsoft.Jet.OLEDB.4.0 '공급자가 로컬 컴퓨터에 등록되어 있지 않습니다 - 리뷰나라

32 비트 Windows 2008 서버에서 .NET 3.5로 개발 된 Windows 응용 프로그램을 만들었습니다. 64 비트 서버에 응용 프로그램을 배포하면 “Microsoft.Jet.OLEDB.4.0 ‘공급자가 로컬 컴퓨터에 등록되어 있지 않습

daplus.net

 

 

반응형
728x90

https://gist.github.com/ihoneymon/652be052a0727ad59601

 

마크다운(Markdown) 사용법

마크다운(Markdown) 사용법. GitHub Gist: instantly share code, notes, and snippets.

gist.github.com

 

[공통] 마크다운 markdown 작성법

1. 마크다운에 관하여

1.1. 마크다운이란?

Markdown은 텍스트 기반의 마크업언어로 2004년 존그루버에 의해 만들어졌으며 쉽게 쓰고 읽을 수 있으며 HTML로 변환이 가능하다. 특수기호와 문자를 이용한 매우 간단한 구조의 문법을 사용하여 웹에서도 보다 빠르게 컨텐츠를 작성하고 보다 직관적으로 인식할 수 있다. 마크다운이 최근 각광받기 시작한 이유는 깃헙(https://github.com) 덕분이다. 깃헙의 저장소Repository에 관한 정보를 기록하는 README.md는 깃헙을 사용하는 사람이라면 누구나 가장 먼저 접하게 되는 마크다운 문서였다. 마크다운을 통해서 설치방법, 소스코드 설명, 이슈 등을 간단하게 기록하고 가독성을 높일 수 있다는 강점이 부각되면서 점점 여러 곳으로 퍼져가게 된다.

1.2. 마크다운의 장-단점

1.2.1. 장점

1. 간결하다. 2. 별도의 도구없이 작성가능하다. 3. 다양한 형태로 변환이 가능하다. 4. 텍스트(Text)로 저장되기 때문에 용량이 적어 보관이 용이하다. 5. 텍스트파일이기 때문에 버전관리시스템을 이용하여 변경이력을 관리할 수 있다. 6. 지원하는 프로그램과 플랫폼이 다양하다.

1.2.2. 단점

1. 표준이 없다. 2. 표준이 없기 때문에 도구에 따라서 변환방식이나 생성물이 다르다. 3. 모든 HTML 마크업을 대신하지 못한다.


2. 마크다운 사용법(문법)

2.1. 헤더Headers

  • 큰제목: 문서 제목This is an H1 =============

    This is an H1

  • 작은제목: 문서 부제목This is an H2 -------------This is an H2
  • 글머리: 1~6까지만 지원

# This is a H1 ## This is a H2 ### This is a H3 #### This is a H4 ##### This is a H5 ###### This is a H6

This is a H1

This is a H2

This is a H3

This is a H4This is a H5This is a H6

####### This is a H7(지원하지 않음)

2.2. BlockQuote

이메일에서 사용하는 > 블럭인용문자를 이용한다.

> This is a first blockqute. > > This is a second blockqute. > > > This is a third blockqute.

This is a first blockqute.

This is a second blockqute.

This is a third blockqute.

이 안에서는 다른 마크다운 요소를 포함할 수 있다.

This is a H3

  • Listcode

2.3. 목록

● 순서있는 목록(번호)

순서있는 목록은 숫자와 점을 사용한다.

1. 첫번째 2. 두번째 3. 세번째

  1. 첫번째
  2. 두번째
  3. 세번째

현재까지는 어떤 번호를 입력해도 순서는 내림차순으로 정의된다.

1. 첫번째 3. 세번째 2. 두번째

  1. 첫번째
  2. 세번째
  3. 두번째

딱히 개선될 것 같지는 않다. 존 그루버가 신경안쓰고 있다고...

● 순서없는 목록(글머리 기호: *, +, - 지원)

* 빨강 * 녹색 * 파랑 + 빨강 + 녹색 + 파랑 - 빨강 - 녹색 - 파랑

  • 빨강
    • 녹색
      • 파랑
  • 빨강
    • 녹색
      • 파랑
  • 빨강
    • 녹색
      • 파랑

혼합해서 사용하는 것도 가능하다(내가 선호하는 방식)

* 1단계 - 2단계 + 3단계 + 4단계

  • 1단계
    • 2단계
      • 3단계
        • 4단계

2.4. 코드

4개의 공백 또는 하나의 탭으로 들여쓰기를 만나면 변환되기 시작하여 들여쓰지 않은 행을 만날때까지 변환이 계속된다.

2.4.1. 들여쓰기

This is a normal paragraph: This is a code block. end code block.

실제로 적용해보면,

적용예:


This is a normal paragraph:

This is a code block.

end code block.


한줄 띄어쓰지 않으면 인식이 제대로 안되는 문제가 발생합니다.

This is a normal paragraph: This is a code block. end code block.

적용예:


This is a normal paragraph: This is a code block. end code block.


2.4.1. 코드블럭

코드블럭은 다음과 같이 2가지 방식을 사용할 수 있습니다:

  • <pre><code>{code}</code></pre> 이용방식

<pre> <code> public class BootSpringBootApplication { public static void main(String[] args) { System.out.println("Hello, Honeymon"); } } </code> </pre> public class BootSpringBootApplication { public static void main(String[] args) { System.out.println("Hello, Honeymon"); } }

  • 코드블럭코드("```") 을 이용하는 방법

``` public class BootSpringBootApplication { public static void main(String[] args) { System.out.println("Hello, Honeymon"); } } ``` public class BootSpringBootApplication { public static void main(String[] args) { System.out.println("Hello, Honeymon"); } }

깃헙에서는 코드블럭코드("```") 시작점에 사용하는 언어를 선언하여 문법강조(Syntax highlighting)이 가능하다.

```java public class BootSpringBootApplication { public static void main(String[] args) { System.out.println("Hello, Honeymon"); } } ```

public class BootSpringBootApplication { public static void main(String[] args) { System.out.println("Hello, Honeymon"); } }

2.5. 수평선 <hr/>

아래 줄은 모두 수평선을 만든다. 마크다운 문서를 미리보기로 출력할 때 페이지 나누기 용도로 많이 사용한다.

* * * *** ***** - - - ---------------------------------------

  • 적용예





2.6. 링크

  • 참조링크

[link keyword][id] [id]: URL "Optional Title here" // code Link: [Google][googlelink] [googlelink]: https://google.com "Go google"

Link: Google

  • 외부링크

사용문법: [Title](link) 적용예: [Google](https://google.com, "google link")

Link: Google

  • 자동연결

일반적인 URL 혹은 이메일주소인 경우 적절한 형식으로 링크를 형성한다. * 외부링크: <http://example.com/> * 이메일링크: <address@example.com> </address@example.com>

2.7. 강조

*single asterisks* _single underscores_ **double asterisks** __double underscores__ ~~cancelline~~

  • single asterisks
  • single underscores
  • double asterisks
  • double underscores
  • cancelline

문장 중간에 사용할 경우에는 **띄어쓰기** 를 사용하는 것이 좋다.
문장 중간에 사용할 경우에는 띄어쓰기를 사용하는 것이 좋다.

2.8. 이미지

![Alt text](/path/to/img.jpg) ![Alt text](/path/to/img.jpg "Optional title")

 

사이즈 조절 기능은 없기 때문에 <img width="" height=""></img>를 이용한다.

<img src="/path/to/img.jpg" width="450px" height="300px" title="px(픽셀) 크기 설정" alt="RubberDuck"></img><br/> <img src="/path/to/img.jpg" width="40%" height="30%" title="px(픽셀) 크기 설정" alt="RubberDuck"></img>

 

2.9. 줄바꿈

3칸 이상 띄어쓰기( )를 하면 줄이 바뀐다.

* 줄 바꿈을 하기 위해서는 문장 마지막에서 3칸이상을 띄어쓰기해야 한다. 이렇게 * 줄 바꿈을 하기 위해서는 문장 마지막에서 3칸이상을 띄어쓰기해야 한다.___\\ 띄어쓰기 이렇게

  • 줄 바꿈을 하기 위해서는 문장 마지막에서 3칸이상을 띄어쓰기해야 한다. 이렇게
  • 줄 바꿈을 하기 위해서는 문장 마지막에서 3칸이상을 띄어쓰기해야 한다.
    이렇게

3. 마크다운 사용기

3.1. 위지윅(WSYWIG) 에디터

우리가 흔하게 접하는 웹에서 사용되는 에디터(네이버, 다음, 구글 등)이 대부분 위지윅 에디터에 속하며 기본적으로 HTML을 이용하여 스타일을 적용하여 문장을 꾸미는 형태를 취하게 된다. 그래서 하루패드와 같은 마크다운 에디터의 View 영역의 내용을 복사하여 붙여넣기를 하면 대체적으로 View영역에서 보이는 그대로 복사되는 편이다. 다만, 붙여넣기 이후에 문장들을 수정하려고 할 떄 문제가 되는데, 이는 스타일이 포함된 태그가 수정과정에서 변형되면서 전체적인 영향을 끼치는 탓이다. 티스토리 블로그에서는 쉽지 않고... 워드프레스의 경우에는 마크다운으로 작성된 포스트를 HTML로 변환해주는 기능을 활용하는 것이 좋다. 결론은, 복사해서 붙여넣기하면 가급적이면 본문은 수정하지 않는 것이 좋다.

3.2. 깃헙Github, 비트버킷Bitbucket과 요비Yobi 등

최근 유행하는 협업개발플랫폼의 경우에는 마크다운을 변환하는 컨버터 기능을 기본탑재하고 있기 때문에 마크다운 문법으로 작성한 텍스트를 그대로 복사해서 붙여넣거나 업로드하는 것만으로 마크다운의 적용이 가능하다.

3.3. MS워드 적용

View 영역의 항목을 그대로 붙여넣거나 HTML 내보내기 등으로 생성한 파일을 불러오는 형태로 사용가능하다. 적용한 헤더를 워드가 읽어드리면서 목차에 적용하기 때문에 이를 활용하면 목차까지도 손쉽게 적용이 가능해진다.


4. 정리

마크다운은 기본문법만 알고있다면 일반 텍스트편집기에서도 손쉽게 작성이 가능한 마크업언어다. 현재 다양한 도구와 플랫폼에서 지원하고 있기 때문에 더욱 손쉽게 스타일적용된 문서를 작성할 수 있어 점점 널리 사용되고 있다.

마크다운을 이해하고 사용하면서 쉽고 빠르게 스타일문서를 작성해보세요.

저는 Dropbox 프로를 구매해서 집-랩탑-스마트폰이 각각 연동을 시켜서 사용하고 있습니다. 드랍박스에 저장된 마크다운 문서는 Dropbox 웹서비스 상에서 제공하기 때문에 웹상에서 바로 열람할 수도 있어 링크를 걸어서 다른 사람과 공유하는 형식으로 사용하고 있다.


P.S.

최근에는 Notion 을 조금씩 사용중이다. Notion 에서 작성한 문서는 Atom(https://atom.io/), Visual Studio Code(https://code.visualstudio.com/), Notepad++(https://notepad-plus-plus.org/)텍스트 편집기에 복붙(복사하고 붙여넣기)하면 마크다운문법으로 작성된 문장이 기입되고 이지윅 에디터를 제공하는 웹에디터에 붙여넣기 하면 거의 완벽한 형태로 복사된다. 그래서 애용중이다.

○ 참고문서

반응형
728x90
        /// <summary>
        /// Byte[] 를 Struct 로 변환합니다.
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <param name="bytes"></param>
        /// <returns></returns>
        private T ConvertSrtuctFromBytes<T>(byte[] bytes) where T : struct
        {
            int size = Marshal.SizeOf(typeof(T));

            if (size > bytes.Length)
            {
                return default(T);
            }

            IntPtr ptr = Marshal.AllocHGlobal(size);
            Marshal.Copy(bytes, 0, ptr, size);
            T result = (T)Marshal.PtrToStructure(ptr, typeof(T));
            Marshal.FreeHGlobal(ptr);

            return result;
        }
반응형
728x90

이것 처것 필요없이 api 호출을 위한 웹서비스를 만들기 위해서는
아래 처럼 프로젝트를 선택하고 시작한후 Controller 를 추가 후 api 를 작성하면 된다.

(Web API 체크 필수)

아래처럼 솔루션이 구성된 상태에서 

추가>컨트롤러 를 선택하여 Controller 를 추가하면 된다.

반응형
728x90

위 에러는 Nuget 버전을 올려주면 해결된다.

 

참고

https://stackoverflow.com/questions/62764744/could-not-load-file-or-assembly-system-runtime-compilerservices-unsafe

반응형
728x90

Win32 창을 호스팅

 

나중에보기

https://docs.microsoft.com/ko-kr/dotnet/api/system.windows.interop.hwndhost?view=net-5.0 

 

HwndHost 클래스 (System.Windows.Interop)

Win32 창을 WPF(Windows Presentation Foundation) 콘텐츠 내의 요소로 호스트합니다.Hosts a Win32 window as an element within Windows Presentation Foundation (WPF) content.

docs.microsoft.com

https://pythonq.com/so/c%23/1674554

 

c# - HwndHost를 사용하여 WPF 내부의 외부 창을 호스팅하는 올바른 방법 - IT 툴 넷

c# - HwndHost를 사용하여 WPF 내부의 외부 창을 호스팅하는 올바른 방법 출처 c# wpf hwndhost

pythonq.com

https://m.blog.naver.com/PostView.naver?isHttpsRedirect=true&blogId=doridori3510&logNo=30178451955 

 

[WPF] HwndHost 위에 Control 들이 가려질때..

사실 WPF 는 툴 레이아웃을 위한 용도일뿐.. 메인 엔진은 C++ 영역이지. 그래서 메인 화면 또한 Win ...

blog.naver.com

https://stackoverflow.com/questions/6087835/can-i-overlay-a-wpf-window-on-top-of-another

 

Can I overlay a WPF window on top of another?

I have a WPF window, which contains a WindowsFormsHost element. I need to draw things on top of this element, but the nature of WindowsFormsHost means that it's always on the top of the drawing pil...

stackoverflow.com

 

반응형
728x90

docs.microsoft.com/en-us/visualstudio/productinfo/vs-roadmap

 

Visual Studio Roadmap

Visual Studio Roadmap for significant planned features

docs.microsoft.com

 

반응형
728x90

my.visualstudio.com/Downloads?q=visual%20studio%202013&wt.mc_id=o~msft~vscom~older-downloads

반응형
728x90

Ctrl + K, Ctrl + K - 책갈피 설정/해제

Ctrl + K, Ctrl + N - 다음 책갈피

Ctrl + K, Ctrl + P - 이전 책갈피

Ctrl + K, Ctrl + L - 책갈피 지우기

반응형
728x90

.net core 프로젝트에서 GoogleMap 을 사용하려는 아래와 같은 에러가 발생되었다.

 


'...bin/roslyn/csc.exe' 경로의 일부를 찾을 수 없습니다

 

 

위 에러는 도구 > Nuget 패키지관리자 > 패키지 관리자 콘솔 에서 아래 명령을 수행해준 후 다시빌드 하면된다.

 


update-package Microsoft.CodeDom.Providers.DotNetCompilerPlatform -r


 

반응형

+ Recent posts