Microsoft MVP성태의 닷넷 이야기
웹: 38. HTTP Cookie의 expires 시간 형식(RFC7231) [링크 복사], [링크+제목 복사],
조회: 20489
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)
(시리즈 글이 3개 있습니다.)
.NET Framework: 473. WebClient 객체에 쿠키(Cookie)를 사용하는 방법
; https://www.sysnet.pe.kr/2/0/1792

웹: 33. HTTP 쿠키에 한글 값을 설정하는 방법
; https://www.sysnet.pe.kr/2/0/11017

웹: 38. HTTP Cookie의 expires 시간 형식(RFC7231)
; https://www.sysnet.pe.kr/2/0/11892




HTTP Cookie의 expires 시간 형식(RFC7231)

고객사에서 이전 제품의 환경에서는 HTTP Cookie의 expires 날짜가 다음과 같이 들어왔는데,

test=1; expires=Fri 10-May-2019 02:00:00 GMT; path=/

새로운 제품 환경에서는 다음과 같이 "콤마(,)"가 있다고 합니다.

test=1; expires=Fri, 10-May-2019 02:00:00 GMT; path=/

희한한 현상이군요. ^^; 간단한 예제 웹 프로그램을 만들어 HttpCookie를 생성해 보면,

using System;
using System.Web;
using System.Web.UI;

namespace WebApplication1
{
    public partial class _Default : Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            HttpCookie cookie = new HttpCookie("test", "1");
            cookie.Expires = DateTime.UtcNow + TimeSpan.FromSeconds(5);
            cookie.Path = "/";

            this.Response.Cookies.Add(cookie);
        }
    }
}

다음과 같이 시간 포맷에 콤마가 들어간 것을 볼 수 있습니다.

Cache-Control: private
Content-Length: 5035
Content-Type: text/html; charset=utf-8
Date: Fri, 10 May 2019 01:59:55 GMT
Server: Microsoft-IIS/10.0
Set-Cookie: test=1; expires=Fri, 10-May-2019 02:00:00 GMT; path=/
X-AspNet-Version: 4.0.30319
X-Powered-By: ASP.NET
X-SourceFiles: =?UTF-8?B?RTpcY2xvdWRfZHJpdmVcRHJvcGJveFxhcnRpY2xlc1xXZWJBcHBsaWNhdGlvbjFcV2ViQXBwbGljYXRpb24xXERlZmF1bHQ=?=

그뿐만 아니라 "Date" 헤더에도 약간 형식은 다르지만 콤마가 적용된 것을 볼 수 있습니다. 검색해 보면, 이에 대해 RFC7231 문서가 언급됩니다.

Hypertext Transfer Protocol (HTTP/1.1): Semantics and Content - 7.1.1.1. Date/Time Formats
; https://tools.ietf.org/html/rfc7231#section-7.1.1.1

내용인즉 2가지 포맷이 있는데,

HTTP-date    = IMF-fixdate / obs-date

IMF-fixdate 포맷이 바로 위에서 보았던 "Date" 헤더의 시간 형식입니다.

Preferred format:
 IMF-fixdate  = day-name "," SP date1 SP time-of-day SP GMT

An example of the preferred format is
 Sun, 06 Nov 1994 08:49:37 GMT    ; IMF-fixdate

반면 (obsolete로 취급되고 있는) obs-date 포맷은 2가지로 나뉘는데,

obs-date     = rfc850-date / asctime-date

rfc850-date 형식도 역시 콤마를 포함하며 Cookie의 "expires"에 사용된 시간 형식입니다.

rfc850-date  = day-name-l "," SP date2 SP time-of-day SP GMT

Examples of the two rfc850-date format is
  Sunday, 06-Nov-94 08:49:37 GMT   ; obsolete RFC 850 format

유일하게 asctime-date의 경우에만 콤마가 없는데요,

asctime-date = day-name SP date3 SP time-of-day SP year

Examples of the two rfc850-date format is
  Sun Nov  6 08:49:37 1994   ; ANSI C's asctime() format

이건 아예 형식 자체가 다릅니다. 따라서 고객사 측에서 제기한 "Sunday 06-Nov-94 08:49:37 GMT" 문자열이 어떻게 나온 것인지 잘 모르겠습니다. 덕분에 RFC 문서도 보며 정리하긴 했지만... ^^ 혹시 아시는 분 계시면 덧글 부탁드립니다.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 5/10/2019]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 121  122  123  124  125  126  127  128  129  130  131  [132]  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
1789정성태10/22/201422472오류 유형: 253. 이벤트 로그 - The client-side extension could not remove user policy settings for '...'
1788정성태10/22/201424303VC++: 82. COM 프로그래밍에서 HRESULT 타입의 S_FALSE는 실패일까요? 성공일까요? [2]
1787정성태10/22/201432582오류 유형: 252. COM 개체 등록시 0x8002801C 오류가 발생한다면?
1786정성태10/22/201434042디버깅 기술: 65. 프로세스 비정상 종료 시 "Debug Diagnostic Tool"를 이용해 덤프를 남기는 방법 [3]파일 다운로드1
1785정성태10/22/201423144오류 유형: 251. 이벤트 로그 - Load control template file /_controltemplates/TaxonomyPicker.ascx failed [1]
1784정성태10/22/201430738.NET Framework: 472. C/C++과 C# 사이의 메모리 할당/해제 방법파일 다운로드1
1783정성태10/21/201424536VC++: 81. 프로그래밍에서 borrowing의 개념
1782정성태10/21/201421284오류 유형: 250. 이벤트 로그 - Application Server job failed for service instance Microsoft.Office.Server.Search.Administration.SearchServiceInstance
1781정성태10/21/201422009디버깅 기술: 64. new/delete의 짝이 맞는 경우에도 메모리 누수가 발생한다면?
1780정성태10/15/201425885오류 유형: 249. The application-specific permission settings do not grant Local Activation permission for the COM Server application with CLSID
1779정성태10/15/201421096오류 유형: 248. Active Directory에서 OU가 지워지지 않는 경우
1778정성태10/10/201419515오류 유형: 247. The Netlogon service could not create server share C:\Windows\SYSVOL\sysvol\[도메인명]\SCRIPTS.
1777정성태10/10/201422537오류 유형: 246. The processing of Group Policy failed. Windows attempted to read the file \\[도메인]\sysvol\[도메인]\Policies\{...GUID...}\gpt.ini
1776정성태10/10/201419599오류 유형: 245. 이벤트 로그 - Name resolution for the name _ldap._tcp.dc._msdcs.[도메인명]. timed out after none of the configured DNS servers responded.
1775정성태10/9/201420837오류 유형: 244. Visual Studio 디버깅 (2) - Unable to break execution. This process is not currently executing the type of code that you selected to debug.
1774정성태10/9/201427753개발 환경 구성: 246. IIS 작업자 프로세스의 20분 자동 재생(Recycle)을 끄는 방법
1773정성태10/8/201431009.NET Framework: 471. 웹 브라우저로 다운로드가 되는 파일을 왜 C# 코드로 하면 안되는 걸까요? [1]
1772정성태10/3/201419816.NET Framework: 470. C# 3.0의 기본 인자(default parameter)가 .NET 1.1/2.0에서도 실행될까? [3]
1771정성태10/2/201428949개발 환경 구성: 245. 실행된 프로세스(EXE)의 명령행 인자를 확인하고 싶다면 - Sysmon [4]
1770정성태10/2/201422805개발 환경 구성: 244. 매크로 정의를 이용해 파일 하나로 C++과 C#에서 공유하는 방법 [1]파일 다운로드1
1769정성태10/1/201425563개발 환경 구성: 243. Scala 개발 환경 구성(JVM, 닷넷) [1]
1768정성태10/1/201420362개발 환경 구성: 242. 배치 파일에서 Thread.Sleep 효과를 주는 방법 [5]
1767정성태10/1/201425722VS.NET IDE: 94. Visual Studio 2012/2013에서의 매크로 구현 - Visual Commander [2]
1766정성태10/1/201423851개발 환경 구성: 241. 책 "프로그래밍 클로저: Lisp"을 읽고 나서. [1]
1765정성태9/30/201427500.NET Framework: 469. Unity3d에서 transform을 변수에 할당해 사용하는 특별한 이유가 있을까요?
1764정성태9/30/201423728오류 유형: 243. 파일 삭제가 안 되는 경우 - The action can't be comleted because the file is open in System
... 121  122  123  124  125  126  127  128  129  130  131  [132]  133  134  135  ...