프로젝트 시작하면서 또 봐야 할 DB 설계시 정부 표준을 봐야 하기에 또 옛자료들 들추며확인 중이었는데

7월에 업데이트 (5차가 진행됨)

1)공동데이터 포털 공지사항 접속  https://www.data.go.kr/bbs/ntc/selectNoticeListView.do 

 

공공데이터 포털

국가에서 보유하고 있는 다양한 데이터를『공공데이터의 제공 및 이용 활성화에 관한 법률(제11956호)』에 따라 개방하여 국민들이 보다 쉽고 용이하게 공유•활용할 수 있도록 공공데이터(Datase

www.data.go.kr

2) 공공데이터 공통표준용어 검색

검색

결과를 확인하여 최신의 데이터를 확인

용어, 단어, 도메이인 엑셀로 되어 있는 파일(필요에따라서 HWP 파일도 있음)

 

3

3) 해당 최신 글을 들어가서 다운로드 한다.

2022-07 링크

 

확인용으로 남겨 본다.

sql 문의 log 출력을 아름답게 변경하려고 준비 했던 것들이 있었다. ~3.10 에서 사용하던 log 설정 및 CustomFormatter 파일이 있어 그대로 이용중이 었다. 다만, pom 설정을 조금 다르게 가져가다 보니 문제가 발생했다.

 

기본적으로 

https://offbyone.tistory.com/208

 

log4jdbc-remix의 Custom SQL Formatter 만들기(SQL log 줄 바꿈)

SQL Query 로그의 줄을 바꿔서 어느정도 예쁘게 출력하는 방법을 알아보겠습니다. log4jdbc-remix 를 사용해서 쿼리 로그를 만들게 됩니다. 테스트는 전자정부표준프레임워크 비즈니스 템플릿을 MySQL(

offbyone.tistory.com

이 내용을 참조하여 진행하는 것을 원칙으로 하고 설정 끝내고 구동을 했더니 WAS가 시작 되지 않고 아래와 같은

아래 같은 오류가 발생한다.

Property 'logFormatter' 
threw exception; nested exception is java.lang.NoSuchMethodError:
'void net.sf.log4jdbc.SpyLogFactory.setSpyLogDelegator(net.sf.log4jdbc.SpyLogDelegator)'

 

context-datasource.xml 파일의 설정

egovframework.cmmn.Log4JdbcCustomFormatter.java 파일은 위 블로그를 참조로 만들었음.

    <bean id="dataSource" class="net.sf.log4jdbc.Log4jdbcProxyDataSource">
       <constructor-arg ref="dataSource-Spied" />
       <property name="logFormatter"> 
	       <bean class="egovframework.cmmn.Log4JdbcCustomFormatter"> 
	           <property name="loggingType" value="MULTI_LINE" /> 
	           <property name="margin" value="8" /> 
	           <property name="sqlPrefix" value="SQL: ################################################################################################################" /> 
	       </bean> 
    	</property>
    </bean>
    
     <bean id="dataSource-Spied" 설정들 ...

여러 이런식의 파생 문제가 발생하는 경우가 있다. 위처럼 인경우 나 그 근접한 문제인 경우

또는 junit 등의 같이 사용후 오류 등이 있다.

 

log4j의 여러 라이브리의 충돌 인것이다.

 

pom.xml 을 확인해 보자.

 

<!-- log4jdbc driver -->
		<dependency> 
	        <groupId>org.lazyluke</groupId> 
	        <artifactId>log4jdbc-remix</artifactId> 
	        <version>0.2.7</version> 
        </dependency>
        
        <dependency>  
              <groupId>org.slf4j</groupId>  
             <artifactId>slf4j-log4j12</artifactId>  
            <version>1.7.35</version>  
        </dependency>
        
        <!-- 아래가 충돌 : 나중에 삭제함. -->
        <dependency>
            <groupId>com.googlecode.log4jdbc</groupId>
            <artifactId>log4jdbc</artifactId>
            <version>1.2</version>
            <exclusions>
                <exclusion>
                    <artifactId>slf4j-api</artifactId>
                    <groupId>org.slf4j</groupId>
                </exclusion>
            </exclusions>
        </dependency>

나는 이렇게 되어 있었다.  그렇다. log4jdbc 이 충돌 하고 있던 것이다. 하...

googlecode.log4jdbc 부분 전체를 주석으로 변경하고 처리 하면 되는 것이다.

 

알길이 없다 싶어서 기록으로 남겨 놓았다. Java 오류가 발생하는 것도 아니고 말이다.

다른 문제를 찾을 수도 있지만 저런 라이브러리 충돌도 잘 봐야 할것 같다.

2022-05-16 기록

  • 한글로 된 경로가 있는 경우 파이참에 python3.x 다운로드해서 처리 하려고 해도 자동으로 인식 되지 않아서직접 입력해야 함
  • 버전업에 따라서 select or switch 형태의 내부 함수가 추가 (match 문법 생성)  python 3.10 이상
  • https://www.ciokorea.com/news/185423 
  • 공부 할줄 추가 해야 한다. 용법도 다행해지는건 당연하 상태
  • if / elif /else 를 경우 수가 많은 경우 대체로 사용한다.
  • default 값을 지정하고 사용을 권장
match command.split():
    case ["quit"]:
        print("Goodbye!")
        quit_game()
    case ["look"]:
        current_room.describe()
    case ["get", obj]:
        character.get(obj, current_room)
    case ["go", direction]:
        current_room = current_room.neighbor(direction)
        # The rest of your commands go here
    case _:
        # default --> 의식적으로 넣어주는 것이 정신건강에 이롭다.
        pass

출처 : https://peps.python.org/pep-0636/

 

PEP 636 – Structural Pattern Matching: Tutorial | peps.python.org

PEP 636 – Structural Pattern Matching: Tutorial Author Daniel F Moisset Sponsor Guido van Rossum BDFL-Delegate Discussions-To Python-Dev list Status Final Type Informational Created 12-Sep-2020 Python-Version 3.10 Post-History 22-Oct-2020, 08-Feb-2021 Re

peps.python.org

 

echat 사용시 차트를 이미지로 저장 시 옵션에 있는 기능을 사용할 수 있지만

외부 디자인에 넣으려고 할 때도 있다. 찾아보면

 

아래와 같은데 이는 조금 문제가 있다. 확장으로 이미지를 디자인식으로 올린 경우 저장이 동일하게 되지 않는다. 

 // Get canvas information
    let canvas = document.getElementsByTagName("canvas");
    if(canvas&&canvas.length>0){
        // create label
        let tempA = document.createElement("a");
        // Set download name
        tempA.download = "echarts download" +".png";
        // Set address and file type
        tempA.href = canvas[0].toDataURL("image/png");
        document.body.appendChild(tempA);
        // Trigger download event
        tempA.click();
        // Remove Tag
        tempA.remove();
     }

따라서 온전히 저장을 하기 위해서는 echat  내부 api를 사용해야 한다.  

/**
 * @param flNm			저장 파일명 확장자 포함
 * @param chartObj		차트 오브젝트명
 * @param pixelRt		저장 이미지 비율 default 1(1:1)
 * @returns
 */
function downloadURI(flNm, chartObj, pixelRt = 1) {
    var tempA = document.createElement("a");
    tempA.download = flNm ;
    //address 설정하고 파일의 타입 정하기
    tempA.href = chartObj.getDataURL({
        pixelRatio: pixelRt
    });
    document.body.appendChild(tempA);
    //클릭 다운로드 이벤트
    tempA.click();
    //태그를 제거합니다
    tempA.remove();
}

함수로 만들어 보았다.  내부 함수를 이용하면 온전히 이미지로 저장이 가능하다.

 

+ Recent posts