서버 배포시 application.properties를 함께 배포하기 민감하기 때문에 

애초에 프로그램 작성시 application.properties에는 내용을 작성하지않고 

Run Configuration에 작성을 해두는게 편한다.


1. 기존의  application.properties에 작성되어 있는 값을 지우고




2 .아래의 메뉴를 타고 들어가서



3. 아래와 같이 propery와 value에 키와 값을 적으면된다.


주의할점은 property에서 자동완성을 시켜줄 때가 있는 데 웬만하면 사용하지말고 본인이 써야하는 키값 그대로 써야한다

왜냐하면 가끔 자동완성에 spring.test-id 라고 되어있지만 내가 사용해야할 키는 spring.testId 이기 때문이다,



4. 그리고 위에 동그라미친 Common을 통해 설정해놓은 값을 export시켜 다른 곳에 사용할 수 있다. 

JPA ORM을 이용한 @Query의 결과값을 Map, JSON형식으로 바로 만들어주는 방법은 2가지가 있다


1. Map을 이용한다.

2. DTO(POJO, VO)를 생성하여 이용한다.



JPA EntityManager를 이용한 Map형식으로 Mapping하는 방법은 아래 링크에 있다.

1. 2018/10/28 - [Develop/Spring Boot] - Spring boot JPA EntityManager를 이용한 Map형식으로 mapping하기




Spring Boot Json익히기

Spring boot Json 1편, 2편, 3편, 4편, 마지막

1. 2018/11/06 - [Develop/Spring Boot] - Spring Boot Json, JsonObject로 만들기 - JSON 1편

2. 2018/11/07 - [Develop/Spring Boot] - Spring Boot Json, Gson을 이용한 JsonObject to String, String to JsonObject- JSON 2편

3. 2018/11/09 - [Develop/Spring Boot] - Spring Boot Json, Jackson을 이용한 JsonParsing - Json 3편

4. 2018/11/12 - [Develop/Spring Boot] - Spring Boot Deserialization Json, Deserialization JsonString to JsonObject - Json 4편

5. 2018/11/13 - [Develop/Spring Boot] - Spring Boot Json, hashmap to json , JsonObject 만들기- JSON 마지막



Spring boot에서 MySQL JSON 타입 SELECT하는 방법

1. 2018/11/30 - [Develop/Spring Boot] - Spring boot MySQL JSON - MySQL JSON DATA TYPE 값 가져오기



1. Map을 이용.

 

(html편집기가 자꾸 안되서 사진으로 대체합니다)


select 문 안에 new map을 선언한다. 주의할 점으로는 as를 사용하지않으면 Map의 Key값에 숫자가 들어간다. 예를들면 만약 저 위의 코드에 as를 주지 않는다면 {0 : id, 1 : password}라는 숫자가 0부터 증가하는 형식으로 들어가게 되며 as를 주게되면 as 로 선언한 이름이 Key값으로 들어간다. 

 2. DTO(POJO, VO)를 이용하는 방법. 먼저 패키지를 생성하고 DTO(POJO, VO)를 생성한다 ex) net.test.com // 패키지안에 TestDTO.java 생성
public class TestDTO{
   private String id;
   private String password;

   public TestDTO(){}

   public Test(String id, String password){
        this.id = id;
        this.password=password;
   }
   public String getId(){
         return id;
   }
   public void setId(String id){
         this.id =id;
   }

   public String getPassword(){
         return password;
   }
   public void setPassword(String password){
         this.password =password;
   }
}

주의할점은 디폴트 생성자를 필수적으로 생성해줘야 한다. 이후
@Query("select new  net.test.com.TestDTO(t.test_id, t.test_password) from Test t")
	List test();

//위의 값을 가져오는 방법.
List t = testDAO.test();
t.getId()

1번의 Map과 다르게 as를 설정하지 않아도 {id : id} 값으로 잘 받을 수 있다. 하지만 일일이 DTO(POJO, VO) 를 생성해야 하는 번거로움이 존재.


spring.profiles.active 와 외부 properties입력시 주의사항.


https://stackoverflow.com/questions/31038250/setting-active-profile-and-config-location-from-command-line-in-spring-boot

Spring boot에서 개발시 사용할 Log와 배포시 사용할 Log를 profile설정을 통해 구분할 수가 있다.


기존에 작성되어 있는 logback-spring.xml 에서 아래와 같이 추가하면 쉽게 가능하다.




		
			
			


이후 이클립스에서 실행할 때는 상단 메뉴 또는 패키지 우클릭에서 Run -> Run Configuration 에서 아래 사진같이 Profile에 xml에서 지정해놓은 이름을 적어두면 된다.



배포시 서버에서 Jar파일을 이용한 커맨드라인으로 실행할 경우 아래와 같이 실행하면 된다.

java -jar -Dspring.profiles.active=prod test-0.0.1-SNAPSHOT.jar

-jar 뒤에 붙는 -D옵션같은 경우는 항상 Jar파일 앞에 적용해줘야 한다.


  1. 2018.10.23 13:54

    비밀댓글입니다

+ Recent posts