Fiddler HTTPS 데이터 확인
Fiddler 에서 HTTPS 통신 전문을 확인하고 싶을 때 아래와 같이 설정 추가
- 개발툴
- · 2015. 5. 14.
spring의 RestTemplate을 이용하면 대게 다음의 exchange 메소드를 이용하여 외부 API와 연동을 하게 된다.ResponseEntity response = restTemplate.exchange(requestUrl, httpMethod, requestEntity, p); 위의 exchange 메소드를 이용하여 연동을 할 때 HTTP request, response 전문을 로그로 남기고 싶을 때가 있어서 그 방법을 찾아보게 되었다. 첫 번째 방법은 log4j를 이용하여 로그를 남기는 방법인데 이 방법은 한 줄 로그로 남길 수 없다는 단점이 있어 포기했다. 무슨 말이냐하면 아래와 같이 여러 줄로 로그가 기록된다는 것이다. 여러 줄로 출력되는 로그는 멀티 쓰레드 환경에서는 오류에 대한 원인을..
로컬 이클립스 환경에 tomcat 소스를 import하고, 이를 분석할 수 있는 환경을 만드는 방법에 대해서 설명한다. 1. 소스 다운로드http://tomcat.apache.org/download-70.cgihttp://apache.mirror.cdnetworks.com/tomcat/tomcat-7/v7.0.64/src/apache-tomcat-7.0.64-src.zip 2.apache-tomcat-7.0.64-src 디렉토리 tomcat으로 변경 (디렉토리명은 원하는 이름으로 변경하면 된다.) 3.이클립스 > Import > General > Project 생성다운로드 받은 tomcat 소스 폴더 지정해당 프로젝트 > Properties > Project Facets 선택 후 Java에 체크Java ..
라이브 배포툴로 사용하면 좋을 오픈소스 Rundeck에 대해서 정리한다.http://rundeck.org/ 페이지에서 jar파일을 다운로드 받을 수 있으며 설정 방법과 동작 방식을 간단하게 설명하면 다음과 같다. [배포 설정 방법]1. Rundeck 설치 - 설치라고 할 것도 없이 jar 파일 다운로드 후 실행만 해주면 된다. 2. 프로젝트 생성 - Rundeck에서의 프로젝트는 하나의 서비스라고 생각하면 이해하기 쉽다. 흔히 개발을 할 때 여러 개의 서비스를 개발하고, 각 서비스는 별도의 시스템을 할당 받아 라이브 서비스를 하기에 이와 같은 구조를 잡은 듯 싶다. 3. Job 등록 - Job이 하는 역할은 tomcat shutdown, war 배포, tomcat startup 과 같은 일을 담당한다. ..
[유니코드란?]유니코드는 세계 각국의 문자를 하나의 문자코드체계로 제안된 규격이며 기본적으로 한 글자에 2byte(16bit)의 데이터를 사용한다.http://unicode-table.com/ 페이지에 나와 있는 코드들이 세계 각각의 문자를 모두 표현할 수 있는 유니코드들인 것이다.그럼 2byte로 되어 있는 저많은 코드들이 어떻게 한글 또는 알파벳으로 표현되는지 알아보겠다. 먼저 아래 표를 보면 세로 축에 0040 가로축에 1 값이 강조되어 있는 것을 볼 수 있다.해당 값들을 조합하면 0041과 같은 형태가 되는데 이것이 알파벳 A를 표현할 수 있는 2byte의 유니코드이다. 0041 유니코드 값이 A로 변환되는 과정을 확인하기 위해 이클립스에서 테스트를 진행해 보면 다음과 같이 A가 표현되는 것을 확..
SimpleDateFormat 클래스는 쓰레드 세이프 하지 않기 때문에 사용할 때 주의를 해야 한다. 다음은 쓰레드 10개를 실행시켜 SimpleDateFormat의 parse("20150630") 메서드를 동시에 실행시키는 테스트 코드이다. 위의 코드를 실행해 보면 다음과 같이 정상적으로 테스트가 종료되는 경우가 있고, 오류가 발생되는 케이스가 있다. 출력된 로그에 나와 있는 것처럼 테스트 코드에서 의도한 Tue Jun 30 00:00:00 KST 2015 값만 노출되는 것이 아닌 이상한 날짜가 출력되고 있는 것을 볼 수 있다. 이는 Thread safe하지 않은 상태에서 여러 쓰레드가 SimpleDateFormat 을 사용하게 됨으로써 발생되는 현상이다. 오류가 발생하면 그나마 다행이지만 가장 큰 우..
selectKey 조회 시 한 건만 가능했던 것이 MyBatis 3.2.6 버전부터는 multiple select key 가 지원되었다.모르고 있었던 기능인데 회사 동료로부터 알게 되었다.Provides some new features: - Caches nested selects - Lazy loading can be enabled only for specific relations - Supports returning multiple fields in a select key - Some other minor improvements http://blog.mybatis.org/2014/03/mybatis-326-released.html 아래와 같이 쿼리를 만들고 테스트를 해보니 잘 동작한다. 실제 업무에서 ..
부모 페이지와 iframe의 도메인이 서로 다르다면 보안상의 이유로 통신을 할 수 없다.통신을 할 수 없다는 의미는 window.parent와 같이 부모창의 DOM에 접근할 수 없다는 것이다.however, for security reasons, the parent page could not communicate with the child Iframe, nor could the child communicate with the parent. 허나, postMessage를 이용하면 parent -> child 또는 child -> parent로의 메세지 전송을 할 수 있다.child -> parent 로의 메세지 전송 방법에 대해서 알아보면 다음과 같다. 1. parent 페이지가 로딩된다. 2. paren..
Fiddler 에서 HTTPS 통신 전문을 확인하고 싶을 때 아래와 같이 설정 추가
HTTP POST 방식으로의 Request 요청 시 서블릿에서 getParameter("data")를 이용하여 데이터를 뽑아 올 때 주의사항이 있다.내가 삽질했던 내용을 적어보면 다음과 같다.서버 코드의 Controller에 다음의 request handler mapping이 정의되어 있다.@RequestMapping(value = "/test", method = RequestMethod.POST)@ResponseBodypublic String test(HttpServletRequest request) {String reqData = request.getParameter("data");return "success";} 위에 작성되어 있는 handler가 정상 동작하는지에 대해서 테스트 코드를 작성한 후 ..
로그인 되어 있는 상태에서 다음의 메소드를 Async 방식으로 호출한 후 로그인 사용자의 계정 정보를 추출하면 항상 null 값이 나온다.@Asyncpublic void searchLog(Search search) {Authentication auth = SecurityContextHolder.getContext().getAuthentication();String userId = auth.getName();} 스프링 시큐리티는 사용자 인증 후 ThreadLocal 객체에 값을 저장하기 때문에 @Async 기능으로 인한 새로운 쓰레드에서는 사용자 세션 정보를 가져올 수 없다.-> spring security 필터를 통과한 쓰레드만 사용자 로그인 정보를 ThreadLocal에 담는다.