Skip to content

CHICPRO

  • Life Log
  • Cycling Log
  • Photo Log
    • Portrait
    • Landscape
    • Flower
    • Etc
  • Coding Log
  • Information

nginx access log 에 POST 데이터 기록하기

2015-12-11 by 편리

웹서비스 개발 중 디버그나 서비스 공격 등이 있을 때 원인을 파악하고자 사용자의 데이터를 분석할 필요가 있다. 그러나 기본적인 access log 에는 사용자가 직접 요청한 POST 등의 데이터는 기록되지 않기 때문에 nginx access log 에 POST 데이터를 기록하도록 해봤다.

우선 nginx.conf 파일의 http 블럭에 아래와 같이 log 포맷을 지정한다.

log_format  request_log '$remote_addr - $remote_user [$time_local] "$request" '
                        '$status $body_bytes_sent "$http_referer" '
                        '"$http_user_agent" "$http_x_forwarded_for" "$request_body"';

마지막 파라미터 $request_body 가 키 포인트이다. 이렇게 설정하고 server 블럭의 access_log 부분을 아래와 같이 수정한다.

access_log  logs/access.log  request_log buffer=32k;

buffer 부분은 접속이 많은 경우에 로그를 버퍼에 저장한 후 기록하도록 하기 위해 추가됐다.

nginx 설정을 변경했다면 service nginx reload 등의 명령을 실행해 설정을 다시 로드한다. 그런 후 access.log 파일에 데이터가 제대로 기록되는지 확인한다.

Post navigation

Previous Post:

스마트폰 터치 장갑

Next Post:

넥서스 5 안드로이드 6.0.1 OTA

4 Commments

  1. 한태성 says:
    2019-03-22 at 09:47

    안녕하세요

    ajax로 실행되는 특정 파일(예를들면 login.php) 만
    post 데이터를 로그에 남기려면 어떻게 해야할까요?
    405에러를 뿜어버리는데 ㅠㅠ

    Reply
    1. 편리 says:
      2019-03-22 at 09:56

      안녕하세요.
      그런 경우라면 특정파일(login.php)에서 post 데이터를 로그 파일로 남기는 것이 편한 방법인 것 같습니다.

      Reply
  2. 한태성 says:
    2019-04-04 at 18:53

    다시 문의드릴게요
    ajax로 실행되는 특정 파일(예를들면 login.php)만 로그에 post 데이터를 남기게 했더니
    405에러를 뿝습니다.

    Reply
    1. 편리 says:
      2019-04-05 at 18:38

      지난 번 답변을 오해하신 것 같습니다.
      post 데이터를 login.php 파일에서 로그 파일을 생성한 후 데이터를 기록하도록 하는 것이 nginx access log 에 남기는 방법보다 간단한 방법입니다.

      Reply

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.

Recent Posts

  • php 배열 연산에서 + 와 array_merge 의 차이
  • pcntl_fork 를 이용한 다중 프로세스 실행
  • 아이폰 단축어를 이용하여 주중 공휴일엔 알람 울리지 않게 하기
  • 구글 캘린더 전체일정 재동기화
  • OpenLiteSpeed 웹서버에 HTTP 인증 적용
  • OpenLiteSpeed 웹어드민 도메인 연결
  • WireGuard를 이용한 VPN 환경 구축
  • Ubuntu 22.04 서버에 OpenLiteSpeed 웹서버 세팅
  • 맥 vim 세팅
  • 우분투 시스템 터미널쉘 zsh 로 변경

Recent Comments

  • 편리 on 업무관리용 그누보드 게시판 스킨
  • 임종섭 on 업무관리용 그누보드 게시판 스킨
  • 캐논 5D 펌웨어 | Dslr 펌웨어 업그레이드 방법 82 개의 베스트 답변 on 캐논 EOS 30D 펌웨어 Ver 1.0.6 , EOS 5D 펌웨어 Ver 1.1.1
  • Top 5 캐논 5D 펌웨어 Top 89 Best Answers on 캐논 EOS 30D 펌웨어 Ver 1.0.6 , EOS 5D 펌웨어 Ver 1.1.1
  • 편리 on 워드프레스 애니메이션 gif 파일을 mp4로 변환하여 출력하기
  • 임팀장 on 워드프레스 애니메이션 gif 파일을 mp4로 변환하여 출력하기
  • 편리 on Notepad++ NppFTP 플러그인 수동 설치
  • paul-j on Notepad++ NppFTP 플러그인 수동 설치
  • YS on Windows 10 iCloud 사진 저장 폴더 변경
  • 편리 on Docker를 이용한 Centos7 + httpd + php 5.4 개발환경 구축

Meta

  • Log in
  • Entries feed
  • Comments feed
  • WordPress.org
© 2025 CHICPRO | Built using WordPress and SuperbThemes