개인 자료란 (JE)

  서버 커뮤니티

Profile Kobins 대표칭호 없음

Kobins 7e61baba5cec465d89e9b4c5615ae13e

Profile

강좌 자바 에디션(JE) 플러그인 개발

[마시자] 마인크래프트로 시작하는 Java 0강 - JDK 설치 / IntelliJ IDEA 설치 / Paper API 가져오기

2020.02.26 조회 수 9002 추천 수 6
분야 플러그인 
장르 개발자 툴 
게임버전 모든버전 
API 스피곳, 페이퍼 
자료글 http://jetbrains.com/ko-kr/idea/download/ 

4a182932b8728e287affadf3f6c385bd.png

마인크래프트로 시작하는 Java 0강 목차

IntelliJ IDEA 설치 / JDK 설치 / Paper API 가져오기

제목의 의도는?

  저는 마인크래프트가 Java를 입문하기 좋은 플랫폼이라고 생각합니다. 물론 그저 간단한 콘솔 프로그래밍으로 (System.out.println(...)과 같은) 시작하는 것도 기초를 닦는 과정이기에 나쁘지 않다고 생각합니다.

 하지만 콘솔창으로 배우는 것은 조금 심심합니다. 가장 심플하지만 너무 심플해서 흥미도가 낮습니다. 프로그래밍을 시작하는 데에 진입장벽으로 작용하는 것 같습니다.

  마인크래프트는 다릅니다. 귀찮은 기반 작업과 여러가지 제약이 존재하지만, 내가 하던 게임을 마음대로 조작할 수 있습니다. 낮아질 수 있는 흥미도를 끌어올리는 데 좋은 수단입니다. 얕은 지식으로도 잘 갖춰진 라이브러리를 통해 생각하던 대로 작동시킬 수 있습니다.

강좌를 들어가기 전

  • 저는 전문가가 아닙니다.
  • 따라서 내용에 실수, 오류가 있을 수 있으며 지나가는 고수들의 피드백을 바랍니다.
  • IntelliJ를 설치하는 과정에서 생략된 과정이 있을 수 있으며(다 지우고 설치하긴 했는데...) 그에 대한 내용을 제보 바랍니다..
  • https://blog.naver.com/stageroad0820/220870860325 - 제가 배운 블로그입니다. 여기도 들러보시면 좋을 것 같습니다.
  • https://wikidocs.net/book/31 - 위 블로그와 함께 아주 간단한 자바 기초 개념으로 참고하기 좋은 무료 강좌사이트 입니다.
  • 이 강좌글의 내용을 맹신하지 마시고, 오류가 있는 것 같으면 망설이지 말고 제보해주시기 바랍니다..
  • 강좌의 타겟은 분명 개발을 처음 시작하는 사람인데, 어쩌다 보니 생략된 부분이 존재할 수 있습니다. 그런 부분도 제보 바랍니다.

JDK (Java Development Kit) 설치하기

Q. ㅖ...? 자바는 이미 제 컴퓨터에 깔려있는 것 같은데요?

A. 개발을 처음 경험해보는 컴퓨터에는 대부분 JRE (Java Runtime Environment)가 깔려 있을 것입니다. JDK는 자바 프로그램을 개발하기 위한 기반입니다.

JDK 설치 사이트 : https://www.oracle.com/technetwork/java/javase/downloads/index.html 

주의 : 오라클 사의 정책이 바뀌어 JDK를 다운로드 하기 위해서 회원가입이 필요합니다. 오라클 사의 JDK 말고 OpenJDK라는 대안도 있으니 구글에 검색해서 찾아보세요.

92b3ca94f33701a014d561d63b5a06a4.png

dfdf751a4a8e487677915db417f082e3.png

227a9a924a2181fb0b224bde1b14c072.pnge2beb3437078736d2c380709d0134a72.png

하;;

75c85e74a19bd19ed2c7ac73a851fcd5.png

대충 만들어 줍시다. (특정 인물에 대한 비하 의도가 없습니다.)

로그인하면 다운로드 됩니다.

d4b6d77e091079e562314969ee7dc467.png

73ff9b1d78f879131cb41ca2fa34d679.png

cd7d128ae957ad5345d5123043b9a487.png

IntelliJ IDEA 설치하기

IntelliJ IDEA 설치 사이트 : https://www.jetbrains.com/ko-kr/idea/

3b82b1b55475bbba0fb08ea75ee074c2.png

3695aae55b0f19a81cd3a39acef5e7cb.png

5857d9f5d5da48ee546bdf251ff23d39.png

6eafee6899169a2201e8629fbf8583cb.png

4b1cc9ca93a89d55ba10ea403cfc0f31.png

대부분 편의성에 관한 내용입니다.

1 : 바탕화면에 바로가기 추가하기 (64-bit 런처로 시작하는 바로가기 추가)
2 : 대화상자 메뉴 (탐색기[폴더창]에서 우클릭)에서 Open Folder as Project(폴더를 프로젝트로 열기) 메뉴 추가
3 : .java, .groovy, .kt 에 대한 확장자 연결을 추가 (해당파일 더블클릭 시 IntelliJ로 열림)
4 : PATH에 런처 경로 추가 (???)

72e2fd74f85a52e776cc1a0bf458fcf3.png

66d1bf55558b601a55745cb0b0906296.png

조오금 시간 걸림

833415f558a164dc4b3f94c0d6abc339.png6a568ec79cb1ba5efb20e68601b80a65.png

1c1d847300e3e1124c53be44f239bf8a.png

위의 Previous version은 제가 이걸 한 번 지웠다가 다시 깔았기 때문에 남아있는 설정을 불러오는 기능입니다.

4621289ade3e9e89b176e80accfa9f90.png

개인차는 있으나 대부분 Darcula 하더라구요. 눈에 편함 ㅎㅎ;

첫 프로젝트 만들기

97c8c50ffa307f53140bb9b635c13642.png

96fffe259838c6b7c8c5c2db4e94cb4d.png

cf76cfa82aa44810f3b9363b0b2aa2dd.png

ba738b51e1a3f2ba481e3f5677782aaf.png

3a16fe876e95b20b4c749fe73eadf048.png

001d05b73de80cb4dba37c2bec94825c.png

49d0bbf816aa62a933f8a9684927e079.png

Q. ??? 진도가 너무 빠릅니다. 프로젝트는 뭐고 패키지는 뭡니까?

- 프로젝트(Project)는 간단하게 말하면 여러분이 만들 플러그인에 대한 모든 정보, 소스 코드를 담는 하나의 단위입니다.
또한, IntelliJ는 하나의 창에 하나의 프로젝트밖에 담지 못합니다.
하지만 프로젝트 하나로 여러 플러그인(jar 파일?)을 만들 수 있도록 모듈(Module)이라는 기능도 지원하고 있습니다.

- 패키지(Package)는 프로젝트 중 소스 코드를 용도, 내용에 맞게 분류하는 '폴더'의 역할을 합니다.

0213dd3cd43ee2f3ec4f6b7a68864a1e.png

패키지의 이름은 꼴리는 대로 하시면.... 다른 사람이 당신의 프로젝트를 열람하는 데 거부 의사를 표출할 수 있습니다.

<패키지 명명 규칙>

  1. 가급적 대문자는 사용하지 않는 게 좋습니다.
  2. 프로젝트를 만든 사람(단체)의 사이트 도메인의 맨 끝부터 시작합니다.
    (중복 방지를 피하기 위해 가장 중복이 없는 도메인을 사용)
    - com.google.~~~
    - org.bukkit.~~~
    - net.minecraft.server.~~~
  3. 하지만 우리와 같은 개인들은 도메인 같은 것이 없을 것입니다.
    따라서 개인의 경우는 me.<닉네임>.~~~ 으로 하는 경우가 있습니다.
  4. 굳이 자신의 사이트가 아니더라도 com.<닉네임>.~~~ 처럼 사용해도 무방합니다.
    (단 닉네임이 사이트 주소와 일치하는 경우 나중에 해당 라이브러리를 가져올 때 불편함을 겪을 수 있습니다.) 
  5. 서버 전용 플러그인을 개발한다면 자신의 서버 주소 도메인을 사용하는 것도 좋을 것 같습니다. (kr.kro.~~~)
  6. 점 (.)으로 구분합니다. (실제 프로젝트 생성 시 ~~/src/me/kobins/... 와 같은 경로로 구성됨)

굳이 규칙을 따르지 않아도 되지만, 그냥 습관처럼 지키는 것이 좋습니다. 나중에 질문글 올릴 때 패키지 구성이 이상하면 원하는 답변을 받지 못하고 괜히 패키지 이름으로 지적받는 일이 생길 수 있습니다. (물론 플러그인 개발자들 인성이 다 그렇게 쓰레기인 것은 아닙니다)

76461c2a940f51b24e49093d63f83f32.png

패키지 이름이 me.kobins일 경우에 위와 같이 폴더가 생성됩니다.

D:/[JAVA]/MSJ는 아까 위에서 설정한 프로젝트의 경로이며,
src는 해당 프로젝트에서 소스 코드를 담는 폴더,
me/kobins는 우리가 설정한 패키지 이름을 기준으로 생성된 폴더들입니다.

953db7a2cceb0b95b7cd2096a014e668.png

Q. 클래스는 무엇입니까?

A. 사실 깊게 설명하면 객체지향 개념까지 설명해야 하지만, 지금 부분에서는 간단하게 소스 코드 파일 하나 단위 라고만 설명해 두겠습니다. 실제 소스 코드에서는 .java 파일[수정 가능, 원본 소스]로 생성되며, 빌드(컴파일) 후에는 .class[수정 불가능, 실행 소스] 파일로 변환됩니다.

3d8c51cd8b5a322a53fe1e2b62648cc2.png

클래스에도 이름을 짓는 방법이 있습니다.

  1. 영어로 작성하자. (설마 해서 적어놓음)
  2. 맨 처음은 대문자로 시작한다.
  3. 띄어쓰기는 사용하지 않는다.
  4. 단어를 대문자로 시작한다.
    - 만약에 null pointer exception이라는 이름을 쓰고 싶다면 NullPointerException이라는 이름으로 바꾸어야 한다.
    - diamond is unbreakable 이라는 이름도 DiamondIsUnbreakable이라는 이름으로.
  5. 언더바(_)를 사용하지 않는다. (더러워진다.)

또한 띄어쓰기 룰 제외하고는 필수는 아니지만, 패키지 이름과 마찬가지로 질문 대답을 받지 못하고 클래스 이름이 왜 그 꼬라지냐 하는 지적을 받을 수 있으니 지켜줍시다.

43af754eabefdd6bf0fc6087ddeff05c.png

첫 클래스를 만들었습니다.  와!


하지만 이것으로는 아직 플러그인을 만들 수 없습니다 ...


Paper API 가져오기 (1.15.2)

  지금부터 설명할 내용은 거의 꼼수에 가깝습니다. 사실 공식 사이트에서 평범하게 jar 파일로 가져오는 방법을 설명해줄 처지도 아니지만(후술...), 킹직히 너무 불편한 것 같습니다.

  만약 Paper가 아닌 순수 BuildTools 또는 외부 미러를 통해 spigot ~~~.jar 파일을 가지고 개발하실 분들은 중간에 jar 파일을 연결하는 부분에서부터 똑같이 해 주시면 되겠습니다.


왜 이 짓을 해야하는가? (이 부분은 생략해도 됨)

플러그인은 사실 마인크래프트에 원래 존재하는 개념이 아닙니다. 애초에 마인크래프트 서버 자체도 확장을 염두에 둔 구조가 아닌 것 같습니다.
양심이 없거든요. 후... 개빡치네 쓰다보니 NMS야발...

아무튼 그런 서버 기반(Minecraft_Server.jar)을 어떻게든 씹고 뜯고 맛보고 해서 어떤 Java 잘하는 사람이 만든 API가 바로 Bukkit에 해당합니다. 그리고 Bukkit에서는 서버를 원하는 대로 모딩(Modification) 할 수 있도록 플러그인이라는 기능을 제공하죠!

또, Bukkit을 그대로 가져와 최적화를 더한 것이 Spigot이며, 기존에는 대부분 Bukkit 또는 Spigot으로 개발 해 왔습...니다만

정식 1.7 버전에서 1.8 버전으로 넘어가는 과정 중에 버킷 팀 인원과 모장 사이에 정책(EULA...) 관련해서 DMCA 문제(대충 저작권)가 터지면서 더 이상 Bukkit과 이를 기반으로 한 Spigot을 만들기 힘들게 되었습니다. (자세한 건 킹무갓키로...)

아무튼 어찌저찌 해서 나온 새로운 Spigot 기반의 API인 Paper가 등장했습니다. 저작권 문제를 적당히 회피하여 공식 사이트에서 다운받을 수 있지요! 

Paper API 준비하기

  - Paper 서버 기반 파일 다운로드 : https://papermc.io/downloads 

1b0836a108b5802c3f3752fc9375403a.png

 1.15.2의 가장 최신 빌드가 #120이네요. 왼쪽의 구름 버튼을 눌러 다운받아 줍시다.

6258fcdfd7a801df76ebc3c80dcb44a5.png

대충 서버 파일을 둘 장소에 저장합시다.

Q. 어? 잠깐? 나 왜 서버를 여는 준비를 하고 있는 것 같지요?

A. 사실 맞습니다. 안타깝게도 평범하게 jar 파일을 라이브러리로 쓰는 방법은 paper.jar 파일로 불가능합니다.

하지만 Paper가 서버를 열면서 한가지 동작을 하는데, 그것은 바로 모장에서 제공하는 Minecraft_Server.jar 파일을 Paper로 다시 패치하여 실제로 Paper 서버를 돌리는 기반을 만드는 것입니다.

즉, paper.jar는 실제 CraftBukkit, Spigot의 내용이 아닌 그 패치 내용을 담고 있는 것입니다! 그래서 우리는 paper.jar을 그대로 API로서 활용할 수 없지요.

따라서 서버를 한번 열어 이 과정을 한번 해 준 후, 패치된 파일을 jar 라이브러리로서 활용하면 이전에 spigot을 가지고 개발하던 것 처럼 플러그인 개발이 가능해집니다!

1d0ff7a82f5102e01d8f55b412840f0a.png

.서버열기.bat

@echo off
title 서버
java -Xms1024M -Xmx1024M -jar paper.jar --nogui
pause

글을 쓰다보니 다운로드가 되었군요. 적절한 배치 파일을 준비 해 줍시다.

0c413696da7a08a71363f54c97f2ebb2.png

서버를 열고 조금 기다리면 Downloading vanilla jar... 메세지와 Patching vanilla jar... 메세지 이후 바로 서버가 열리려는 모습이 보일겁니다. (그리고 eula.txt를 동의하라면서 바로 서버를 닫아버립니다)

b709d8769ec0f57845a51afcb3126530.png

그리고!!! 같은 서버 폴더에 보면 cache 폴더가 생성되어 있는 것을 볼 수 있는데 !!!!

25f7bc0e5f66542adb0f99ffb4821b7f.png

와! 여기 있군요! 우리가 찾던 바로 그 파일입니다. 이제 이 녀석을 IntelliJ 프로젝트에 라이브러리로 등록 해 줍시다.

2cfab6dc590b6d4e0ab61f37f90bca28.png

프로젝트를 우클릭하고 모듈 설정을 열어줍시다.

3b0f9d21536b65575af82362f0f11696.png

Libraries 탭 -> + 버튼을 눌러 Java를 선택 해 줍시다.

5700dfe9694f8036ea8e65ed21d704ba.png

(바로 갱신이 되지 않을 때도 있으니...) 새로고침을 한번 눌러준 후 경로를 찾아 patched_1.15.2.jar 를 클릭하고 OK를 눌러줍시다.

3bf2c990a022602aa8c810ac5e976001.pnga0ee3fda6ca28c4ee8cf1be336156265.png

62df0002eaa1d90deef9a1b05c9d0e35.png

WA! 이제 Paper (Spigot (Bukkit)) 라이브러리가 우리 손 안에 들어와 플러그인 개발을 시작할 수 있게 되었습니다!

API도 생긴 김에 이제 플러그인 강좌 국룰인 onEnable과 onDisable에 메세지 띄우기를 해볼까요?


플러그인 강좌 국룰 해보기 아직 내용 이해까진 안 해도 됨

6c7eab470d1974c680ec26ec671b6976.png

처음에 만든 Main 클래스에 오른쪽에 extends JavaPlugin 을 붙여줍시다.

이게 뭐 하는 짓이냐구요? 객체지향 개념 중 하나인 상속으로 부모 클래스의 속성을 자식 클래스에 적용시켜 부모 클래스가 할 수 있는 일을 그대로 물려받아 기능을 확장하는 개념 중 하나인데 ...



... 는 나중에 다뤄보도록 하죠. 이제 막 시작한(아마?) 여러분들에게는 조오금 벅찬 과정일 수 있습니다.

다른 언어에서 오신 분들도 있을까 싶어 말해두지만 그냥 Paper(Spigot(Bukkit)) API에서 메인 클래스로 인식할 수 있도록 JavaPlugin 클래스를 상속 시켜주는겁니다. 처음 시작하신 분들은 이 내용은 넘겨 들으셔도 됩니다.


어? 근데 빨간색이 뜨죠? 대체 뭐가 문제인가요? 분명 라이브러리도 추가했는데?


마우스를 한번 빨간색 위에 올려봅시다.

6f2ce912dcfd20fcc82b2aa0a4c9d8c9.png

Q. JavaPlugin 이라는 기호를 알아먹을 수 없다는 데, 지금 저한테 약파는 건가요?

A. ㅎㅎ; 사실 어떤 언어든(아마?) 외부 라이브러리를 프로젝트에 가져왔다고 해서 바로 써먹을 수 있는 건 아닙니다.

바로 import 라는 기능이 필요하지요.

import란? 

외부 라이브러리, 또는 자바 내장 라이브러리에서 외부 클래스를 이 코드에서 사용(참조)할 수 있도록 하는 명령.

... 이라고 하면 너무 딱딱한데, 요약하면 Paper API 내에 어딘가에 있는 JavaPlugin 이라는 클래스 내용을 우리가 이 코드에 쓰겠다고 Java에게 선언하는겁니다. 즉, 라이브러리에 아무리 jar 파일을 가져와도 import를 하지 않는다면 아무것도 할 수가 없습니다!

d64ddf58eef50c3ef6270f6501c5f674.png

아무튼, 일단 저 사진의 밑에 있는  Import class를 눌러봅시다.

1aec83534aa4fc41fc463a87216afec4.png

오, 뭐가 생겼네요? 우리 Intellectual한 IntelliJ는(사실 대부분의 IDE도 이정도는 합니다 ㅎㅎ) 대충 해당되는 클래스 이름을 입력하면 알아서 클래스가 위치한 패키지(여기서 나오네요!)를 찾아 자동으로 import 해줍니다.

보시면 알겠지만 대부분의 Paper(Spigot(Bukkit)) API의 클래스는 org.bukkit 패키지 내부에 위치하고 있습니다. 

이제 Main 클래스는 JavaPlugin의 속성을 지닙니다. 즉, 이제 플러그인의 메인 클래스로서 사용할 수 있다는 뜻입니다.


Q. 메인 클래스?

Bukkit은 서버를 열면 자동으로 서버 폴더\plugins\ 내에 있는 모든 .jar 파일들을 검사합니다. 그리고 후술할 plugin.yml 파일의 정보를 토대로 JavaPlugin을 상속한 클래스를 찾게 되는데, 이것이 메인 클래스입니다.

plugin.yml 설정은 조금 이따가 다루기로 하고, 일단은 서버가 켜질 때꺼질 때, 콘솔에 메세지가 가도록 해 봅시다!


서버가 켜질 때 메세지 띄우기

92d3579c8dec480219c5d9fa9c78a80d.png

두 중괄호 사이에 공간을 넉넉~ 하게 만들어 주신 후, 그 빈 공간에 onenable을 써 보면 저런 모습이 뜰 겁니다.

저 상태에서 엔터를 누르면...

 84409cccfb4efb834fdac74ca2feb647.png

와! 이런 모양새가 나왔네요!

IntelliJ의 기능 중 하나인데, 알아서 부모 클래스의 기능을 Override하는 메소드를 자동으로 작성해 주는 기능입니다.

뭐, 자세히 알 필요는 없고, 저 드래그 된 부분을 잠시 지워두고, 우리가 원하는 내용을 써 봅시다.

여기서부터 콘솔에 메세지를 띄우는 방법이 강좌마다 다르던데, 일단 Logger 클래스를 활용하는 방법으로 가 보겠습니다.

9dde8252b93e38faa8b0ea2062cc9b28.png

잠깐 onEnable 안의 중괄호를 나와, 다시 Main 안의 중괄호 공간에 Logger logger = getServer().getLogger(); 를 작성해봅시다.

93547354bde1dfa8d71aaa8d15bad038.png

오, Logger만 쳐도 뭐가 바로 나오네요. 엔터를 눌러 import 해 줍시다.

35a7e7e2bb58d578824596e564dc301f.png

짜잔, 쓰던 거 계속 써 줍시다.

f4bd000bfec5117402ad0882b11b3c43.png

이름까지 자동으로 제안해주는 갓-IntelliJ

859aa514d4cf84426eaf53988e12a00f.png

알아서 찾아주네요. 엔터!

3a0e25c6e8ebc6ee12e7412b8665f8a2.png52f73ddfeaefaf2363fae8afb678c3d8.png

이제 우리는 다른 플러그인에서 보던 것처럼 INFO, WARN, ERROR를 구분해서 콘솔에 메세지를 띄울 수 있습니다.

어떻게 하냐구요?

05a360face6028a5b1f5d9732a3086f7.png

바로 이렇게! logger.info("MSG 플러그인 활성화"); 를 작성 해 주세요. 이러면 매 번 서버가 켜질 때(정확히는 이 플러그인이 가져와질 때) MSJ 플러그인 활성화라는 메세지가 나올겁니다.


꺼질 때 메세지 띄우는것도 비슷합니다.

e97a1f2c80a9ab5cb1343a78ca71d666.png 

b8a6a87e473a614c1236d9419a2edfd9.png

 af495bbe883a6ee4711bee33ebee9f67.png

와! 이제 끌 때도 MSJ 플러그인 비활성화 라는 메세지가 나오겠네요!


plugin.yml 작성하기

음... 근데 대충 기능은 다 작성한 것 같은데, 생각해보니 과연 Paper가 이렇게만 해서 우리 플러그인을 인식할 수 있을 것 같나요?

아마도 그랬다면 Paper가 서버를 시작할 때 대규모 플러그인의 경우는 모든 클래스를 다 뒤지느라 부팅하는 데에만 10분이 걸렸을 것 같은데... 그건 아닌 것 같죠?

따라서 Paper가 우리의 플러그인을 인식할 수 있도록 플러그인의 기본적인 정보를 담는 plugin.yml 파일을 작성 해 봅시다!

a4d41c7654d9ebb48897c930e79aa707.png

일단 폴더를 하나 만들어 줍시다. 프로그램 소스 외에 여러가지 파일을 담을 공간의 목적입니다.

bc756bdb27c7aa5f9f551efecf0a116d.png

resources 라는 이름으로 만들어줍시다.

ad918c7bc508f76bb33d3fea228a1eed.png

파일을 하나 생성해 줄 겁니다.

6c807ae97d8abbcdf96b2bc0bfe2e29c.png

plugin.yml 이라는 이름으로 하나 파일을 만들어 줍시다. 엔터!

999d2eaafea189011e839c554526575a.png

펼쳐진 공허한 공간 ...

우리는 여기에 플러그인에 필요한 기본 정보들을 담을 것입니다.

그럼 대체 플러그인에 필요한 기본 정보가 뭐냐?

name: MSJ
version: 1.0
main: me.kobins.Main
api-version: 1.15

nameversion은 그냥 평범한 문자열로 각각 플러그인의 이름과 버전을 적어주시면 됩니다.

main은 위에서 말한 메인 클래스의 경로를 가져오시면 되는데 ...

594062a9346d0629fddbb13fcc7059f0.png

저기 있는 me.kobins 에다가 뒤에 점.이랑 클래스 이름 Main 붙이시면 me.kobins.Main 완성!

그리고 최근 버전 오면서 생긴 내용인 api-version: 1.15도 추가해줍시다. (안써주면 Paper가 싫어함)

eceb6cc7c7c6812548123509dcbc3c00.png

짜잔~ (노란 음영은 무시해도 됨. String 들어갈 공간에 숫자 썼다고 경고하는 중... 어차피 버전인데...)
그리고 Ctrl+S를 눌러 저장해줍시다!

(※인텔리제이에서는 이것도 자동완성을 해 줍니다. 앙 기모띠) 

그럼 진짜로 우리는 Paper 플러그인을 만들 준비가 다 되었습니다! 이제 jar 파일로 뽑으면 되는데...

IntelliJ에는 jar로 추출하기 위해 한 가지 과정이 필요합니다.


Artifact 설정하기

이 기능은 IntelliJ의 모듈을 원하는 형태로 Export할 수 있게 만든 기능입니다.

우리는 Jar 형태로 Export하여 우리 서버에 한번 넣어봐야지요?

fdd06f4f004d88ed044b299d7e0fd1e6.png

아까 들어갔던 모듈 설정을 들어가줍시다.

c9892ec4f8aea456208d26acd64e9b3d.png

순서대로 Artifacts -> + 버튼 -> JAR -> Empty를 눌러줍시다.

8c900c99b962a8a58b204a4c0f4619f9.png

unnamed라는 친구가 생겼을 텐데, 원하는 이름으로 일단 바꿔줍시다.

edbffbe2dbc0daf2f084db40b6e05c56.png

음... 좋아요.... 그리고 경로를 설정 해 줍시다. 우리는 플러그인을 수정하고 바로바로 그 결과를 보고싶으니 서버의 플러그인 폴더로 설정 해 줍시다!

389efbd2769598765b4f31d29d88535d.png

저 폴더 모양을 누르면 경로를 지정할 수 있습니다.

728c723414a0432b85568c990b87c044.png

아까 대충 페이퍼를 다운받은 폴더나, 아님 따로 구축해둔 서버가 있으면 그 서버 폴더의 plugins에 지정 해 줍시다.

만약에 아까 페이퍼를 다운받은 폴더에 하면 아마 서버를 제대로 열지 않고 와서 plugins 폴더가 없을테니, 위의 폴더 생성 버튼으로 plugins 폴더를 만들어 준 뒤에 OK를 눌러줍시다.

b2228855466d7dad78918ec31c8f24dc.png

그리고 사진의 화살표를 눌러 저 'MSJ' compile output을 더블클릭 해 봅시다.

b4868fd6eda010e3286ad3fb383b5ca0.png

짜잔! 이제 우리가 만들 jar 파일에 MSJ 모듈의 내용들이 들어가게 되었습니다.

그리고 우리가 아까 만든 plugin.yml도 jar 파일에 포함시켜 봅시다.

2da29761f809184fe6cf713bd9855344.png

왼쪽의 + 버튼을 눌러 Directory Content 선택

54d1b00255efa7e24bde9f05bc19f6cc.png

프로젝트 폴더에 들어가 아까 만들어둔 resources 폴더 선택

f976716ff835528ae11db1a1b03ef34d.pngd62fedd235d1df25c13a69268e1d8d77.png

이제 resources 폴더 안에 있는 모든 친구들은 전부 jar로 만들어질 때 같이 나갑니다.

그리고 그 resources 폴더 안에 plugin.yml 파일을 Paper가 찾아서 플러그인의 정보를 읽고

아까 적어둔 main: me.kobins.Main의 정보를 토대로 우리의 플러그인을 로드할겁니다!

89c239bbd63739a3121a8b78a8182f3d.png

OK!

6b0301ac1d715eb3399f8cef93123876.png

이제 우리가 설정한 jar를 진짜로 뽑아낼 시간입니다. Build -> Build Artifacts... 를 눌러주세요! (단축키는 제가 임의로 설정)

2a1b4096a5cdd46d85b83b02c9f07f70.png

Build!!!

a7dfbd248aadd20a0cc9fd9a81d663c7.png

13da8549e5c236c984629e0f1fd1cb14.png

좋아요!!!

2198ff5f00d67fd078ef7041a270d561.png

짜란 !!!!!!!

838c42ba4c363abdf7445d997bba1f8e.png

아까 서버를 열면서 생긴 eula.txt 파일의 내용을 true로 바꿔주고... (이거 안하면 서버 못염)

103aac18624d620b6ad3db15e903111c.png

가즈앗
04c373cb8a6440ed78274b6f506dc321.png

아주 긴 시간의 월드 생성 후...

0bc79c3fb6ebbe32a6049113ef6e4da1.png

아!!!!!!!!!!!!!!!!! 바로 이거야!!!!!!!!!!!!!!!!!!!!
bed8e77aee24af236737dbcd862fb45b.png

끄면?

4162d692b4824bfec2b0c67e39127c35.png

이예아!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!


목차




56개의 댓글

Kobins
2020.10.24
@플러그인개발이고픈닝겐

1.12.2 spigot을 구해서 바로 라이브러리에 넣어주면 됩니다.

너의앞내는
2020.11.21

1.16.3 버전 Nukkit Plugin을 만들려고 하는데 처음 부분과 중간 부분은 잘되는데 마지막에 Nukkit Sever 파일에 있는 Plugin 파일에 넣어서 작동 시켰는데 Plugin 을 인식을 못허내요. 어떻게 하죠?

김레유
2020.12.08

version과 api-version에 정확히 뭘 쓰는 건가요?

 

허두
2020.12.08
@김레유

version은 그냥 아무거나 쓰셔도 됩니다. 그냥 자신의 플러그인의 버전을 자기가 원하는 대로 구별하기 위해 쓰는 것이거든요.

api-version은 1.13 버전 이상의 플러그인에만 쓰시면 됩니다. 마크 버전에서 맨 뒷 자리를 제외하고 적으시면 됩니다.

예를 들어, 1.13.2인 경우에는 1.13을, 1.16.4인 경우에는 1.16을, 1.15인 경우에는 1.15를 쓰시면 됩니다.

김레유
2020.12.10
@허두

파일 이름을 yml이라고 써도 일반 파일로 나오고 yml파일 로 나오지 않는데, 어디서 문제인 걸가요?

 

허두
2020.12.10
@김레유

New -> FIle을 선택하시고 파일 이름.yml 이라고 적으신거 맞죠?

정 안되면 Export 후에 윈도우 탐색기에서 직접 바꿔주시는 방법도 있습니다

김레유
2020.12.10
@허두

네 감사합니다

강예준개발자
2024.05.21
@김레유

Version은 플그 버전이고 api-version은 마크 버전입니다. 둘다 ' 를 해줘야합니다

김레유
2020.12.17

yml 파일이 plugin.yml 이 아니라p를 대문자로 써야만 yml파일로 나오는데 상관없나요?

 

D!4
2021.01.04

좋은 글 감사합니다!

덕분에 플러그인 개발 쉽게 배울 수 있을거같네요 ㅎㅎ

류시월
2021.02.18

뭐가 문제일까요?ㅠㅠㅠ

[16:49:23 ERROR]: Could not load 'plugins\MSJ.jar' in folder 'plugins'

org.bukkit.plugin.InvalidPluginException: java.lang.UnsupportedClassVersionError: me/kobins/Main has been compiled by a more recent version of the Java Runtime (class file version 59.0), this version of the Java Runtime only recognizes class file versions up to 52.0

at org.bukkit.plugin.java.JavaPluginLoader.loadPlugin(JavaPluginLoader.java:141) ~[patched_1.16.5.jar:git-Paper-457]

at org.bukkit.plugin.SimplePluginManager.loadPlugin(SimplePluginManager.java:397) ~[patched_1.16.5.jar:git-Paper-457]

at org.bukkit.plugin.SimplePluginManager.loadPlugins(SimplePluginManager.java:305) ~[patched_1.16.5.jar:git-Paper-457]

at org.bukkit.craftbukkit.v1_16_R3.CraftServer.loadPlugins(CraftServer.java:389) ~[patched_1.16.5.jar:git-Paper-457]

at net.minecraft.server.v1_16_R3.DedicatedServer.init(DedicatedServer.java:206) ~[patched_1.16.5.jar:git-Paper-457]

at net.minecraft.server.v1_16_R3.MinecraftServer.w(MinecraftServer.java:936) ~[patched_1.16.5.jar:git-Paper-457]

at net.minecraft.server.v1_16_R3.MinecraftServer.lambda$a$0(MinecraftServer.java:174) ~[patched_1.16.5.jar:git-Paper-457]

at java.lang.Thread.run(Unknown Source) [?:1.8.0_281]

Caused by: java.lang.UnsupportedClassVersionError: me/kobins/Main has been compiled by a more recent version of the Java Runtime (class file version 59.0), this version of the Java Runtime only recognizes class file versions up to 52.0

at java.lang.ClassLoader.defineClass1(Native Method) ~[?:1.8.0_281]

at java.lang.ClassLoader.defineClass(Unknown Source) ~[?:1.8.0_281]

at java.security.SecureClassLoader.defineClass(Unknown Source) ~[?:1.8.0_281]

at org.bukkit.plugin.java.PluginClassLoader.findClass(PluginClassLoader.java:178) ~[patched_1.16.5.jar:git-Paper-457]

at org.bukkit.plugin.java.JavaPluginLoader.getClassByName(JavaPluginLoader.java:216) ~[patched_1.16.5.jar:git-Paper-457]

at org.bukkit.plugin.java.PluginClassLoader.findClass(PluginClassLoader.java:122) ~[patched_1.16.5.jar:git-Paper-457]

at org.bukkit.plugin.java.PluginClassLoader.findClass(PluginClassLoader.java:111) ~[patched_1.16.5.jar:git-Paper-457]

at java.lang.ClassLoader.loadClass(Unknown Source) ~[?:1.8.0_281]

at java.lang.ClassLoader.loadClass(Unknown Source) ~[?:1.8.0_281]

at java.lang.Class.forName0(Native Method) ~[?:1.8.0_281]

at java.lang.Class.forName(Unknown Source) ~[?:1.8.0_281]

at org.bukkit.plugin.java.PluginClassLoader.(PluginClassLoader.java:79) ~[patched_1.16.5.jar:git-Paper-457]

at org.bukkit.plugin.java.JavaPluginLoader.loadPlugin(JavaPluginLoader.java:137) ~[patched_1.16.5.jar:git-Paper-457]

... 7 more

허두
2021.04.25
@류시월

자바 버전이 안맞는듯 합니다. 컴파일된 버전이 서버 구동에 사용된 버전보다 높네요.

Manage Project Settings -> Projects 에서 자바 버전 변경해주셔야 할것 같습니다.

킬육
2021.08.30

[17:03:12 ERROR]: Could not load 'plugins\mcpcpl.jar' in folder 'plugins'

org.bukkit.plugin.InvalidPluginException: Cannot find main class `me.sgkill6.Main'

at org.bukkit.plugin.java.PluginClassLoader.(PluginClassLoader.java:73) ~[patched_1.17.1.jar:git-Paper-229]

at org.bukkit.plugin.java.JavaPluginLoader.loadPlugin(JavaPluginLoader.java:153) ~[patched_1.17.1.jar:git-Paper-229]

at org.bukkit.plugin.SimplePluginManager.loadPlugin(SimplePluginManager.java:414) ~[patched_1.17.1.jar:git-Paper-229]

at org.bukkit.plugin.SimplePluginManager.loadPlugins(SimplePluginManager.java:322) ~[patched_1.17.1.jar:git-Paper-229]

at org.bukkit.craftbukkit.v1_17_R1.CraftServer.loadPlugins(CraftServer.java:410) ~[patched_1.17.1.jar:git-Paper-229]

at net.minecraft.server.dedicated.DedicatedServer.init(DedicatedServer.java:276) ~[patched_1.17.1.jar:git-Paper-229]

at net.minecraft.server.MinecraftServer.x(MinecraftServer.java:1141) ~[patched_1.17.1.jar:git-Paper-229]

at net.minecraft.server.MinecraftServer.lambda$spin$0(MinecraftServer.java:318) ~[patched_1.17.1.jar:git-Paper-229]

at java.lang.Thread.run(Thread.java:831) [?:?]

Caused by: java.lang.ClassNotFoundException: me.sgkill6.Main

at org.bukkit.plugin.java.PluginClassLoader.loadClass0(PluginClassLoader.java:146) ~[patched_1.17.1.jar:git-Paper-229]

at org.bukkit.plugin.java.PluginClassLoader.loadClass(PluginClassLoader.java:103) ~[patched_1.17.1.jar:git-Paper-229]

at java.lang.ClassLoader.loadClass(ClassLoader.java:519) ~[?:?]

at java.lang.Class.forName0(Native Method) ~[?:?]

at java.lang.Class.forName(Class.java:466) ~[?:?]

at org.bukkit.plugin.java.PluginClassLoader.(PluginClassLoader.java:71) ~[patched_1.17.1.jar:git-Paper-229]

... 8 more

 

무슨 문제가 있는걸까요

sino
2021.11.01
@킬육

me.sgkill6.Main을 찾을수 없데요

jungwoo210
2021.12.19
@sino

어떻게 해결하죠....

꿈틀
2022.08.10

paper api를 얻으려고 하는데.. patched jar가 폴더에 없더라고요

paper 디스코드에서 찾아보니

 

the patched jar is no longer fully loaded with dependencies and so we don't bother producing dependency notation information anyways because you can't build against such a jar due to spigots changes anyways

just use maven or gradle

라고 하더군요

 

그 말은 더 이상 상위버전의 paper api를 가져오려면 patched jar을 얻을 수 없고 maven이나 gradle로만 사용할 수 있다는 이야기인데.. 이 방법도 알려주실 수 있나요?

뉴스 및 창작물
/files/thumbnails/761/908/003/262x150.crop.jpg?20241025153749

건축

서울 숭례문(崇禮門) 4

KHC

2024-10-25

2

/files/thumbnails/578/899/003/262x150.crop.jpg?20241010142350

건축

경주 월정교 1

KHC

2024-10-10

2

/files/thumbnails/219/899/003/262x150.crop.jpg?20241009200950

건축

송전탑+도시 2

dbasd12

2024-10-09

2

/files/thumbnails/246/898/003/262x150.crop.jpg?20241008102328

레드스톤

단다단 - 오토노케(オトノケ) | 마인크래프트 노트블럭 커버

노트블럭전문가

2024-10-08

1

/files/thumbnails/348/896/003/262x150.crop.jpg?20241006103035

디도스/봇테러등등을 낚는 방법 4

물귀신

2024-10-06

3

/files/thumbnails/839/895/003/262x150.crop.jpg?20241006021227

SRV레코드는 보안도메인이 아닙니다. [서버오픈시 필독]

물귀신

2024-10-05

4

/files/thumbnails/648/892/003/262x150.crop.jpg?20241002184058

아티클

마인크래프트 라이브 2024 후기: 무성의가 느껴졌던 '절망편' 라이브

라비

2024-10-02

4