ویکی‌پدیا:استاندارد X.509

از ویکی‌پدیا، دانشنامهٔ آزاد

مقدمه[ویرایش]

X.509 یک استاندارد ITU-T است که به طور گسترده برای تعریف گواهی دیجیتال در زیرساخت کلید عمومی استفاده می‌شود. این استاندارد فرمت گواهی کلید عمومی، لیست گواهی‌های لغو شده ، ویژگی‌ گواهی‌ها و روش اعتبارسنجی مسیر گواهی را مشخص می‌کند. تاکنون سه نسخه از این استاندارد منتشر شده است. این استاندارد برای اولین بار در سال 1988 به عنوان قسمتی از استاندارد سرویس‌های دایرکتوری ITU X.500 منتشر شد. این استاندارد در سال 1993 مورد بازبینی مجدد قرار گرفت و به ساختار آن دو فیلد اضافه و به عنوان نسخه دوم منتشر شد. هدف از افزودن این دو فیلد، پشتیبانی از کنترل دسترسی به دایرکتوری بود. این استاندارد سپس مجددا مورد بازبینی قرار گرفت و در RFC 2459 به ساختار آن تعدادی فیلد توسعه افزوده و سپس به عنوان نسخه سوم منتشر شد. هدف از افزودن این فیلد‌های توسعه، ذخیره کردن اطلاعات اضافی در مورد گواهی دیجیتال مثل کاربردهای آن است. به طور کلی در حال حاضر اصطلاح X.509 تنها برای نسخه سوم این گواهی به کار می‌رود. تاکنون برای نسخه سوم این گواهی چندین RFC از جمله RFC 4325، RFC 4630 و RFC 5280 منتشر شده است. در هر یک از این RFCها تعدادی فیلد توسعه به استاندارد X.509 افزوده شده است.

ساختار گواهی[ویرایش]

ساختار پیش‌بینی شده برای فیلدهای این گواهی با فرمت ASN.1 ذخیره می‌شوند. ASN1 استانداردی است که برای کد کردن و دیکد کردن داده‌ها در سطح شبکه به کارمی‌رود. دلیل استفاده از این نحوه‌ی کدگذاری برای ذخیره گواهینامه X.509 مستقل از ماشین بودن این فرمت است و به راحتی توسط هر ماشینی قابل کد و دیکد کردن است. ساختار گواهی دیجیتالی x.509 نسخه 3 به شکل زیر است:

توضیحات نام فیلد
این فیلد نشان‌دهنده‌ی نسخه گواهی است Version
این فیلد دربردارنده‌ی سریال گواهی است. این سریال باید به ازای هر مرکز صدور گواهی منحصر‌به‌فرد باشد. Serial Number
این فیلد نشان‌دهنده‌ی روش تولید چکیده و الگوریتم رمزی است که این گواهی به وسیله‌ی آن توسط مرکز صدور گواهی امضا شده است. Signature Algorithm
این فیلد اطلاعات صادرکننده گواهی را نشان می‌دهد. Issuer
این فیلد تاریخ شروع اعتبار گواهی را نشان می‌دهد. Valid from
این فیلد تاریخ پایان اعتبار گواهی را نشان می‌دهد. Valid to
این فیلد اطلاعات فرد یا مرکزی که گواهی برای او صادر شده است را نشان می‌دهد. Subject
این فیلد نشان‌دهنده‌ی الگوریتمی است که کلید عمومی آن در این گواهی قرار داده شده است. مثل RSA یا DSA Algorithm
این فیلد حاوی کلید عمومی گواهی است Public Key
توضیح این فیلد در پایین جدول آورده شده است. Extensions

فیلد Extension[ویرایش]

این قسمت از گواهی اختیاری است. و تنها در نسخه 3 وجود دارد. این قسمت اطلاعات اضافی در مورد گواهی را دربرمی‌گیرد. این قسمت به هر تعداد دلخواه می‌تواند فیلد توسعه داشته باشد. هر یک از این فیلدهای توسعه برای خود یک شناسه دارد. به این شناسه اصطلاحاOID گفته می‌شود. این OIDها را به طور کلی می‌توان به سه دسته تقسیم کرد.

  • قیدهای پایه‌ایی
این نوع OID برای اینکه مشخص کنند این گواهی متعلق به کدام مرکز صدور گواهی است به کار می‌‌رود.
  • قیدهای نحوه استفاده از کلید
این نوع OID مشخص کننده قیدهایی است که برای موارد استفاده کلید عمومی محدودیت ایجاد می‌کند. مثلا مشخص می‌کند که کلید عمومی قرار گرفته در این گواهی تنها باید برای پروتکل SSL مورد استفاده قرار بگیرد نه امضای دیجیتال.
  • قیدهای توسعه‌ایی استفاده از کلید

این نوع OID نیز مثل نوع قبلی برای ایجاد قیدهایی بر روی نحوه استفاده از کلید به کار می‌رود. این OID ها جمع عام نیز دارد و افراد نیز می‌تواند با توجه به نیازشان برای خود OID جدید تعریف کنند. اما این OID از آنجایی که درون استاندارد X.509 تعریف نشده است تنها برای شخص صادر کننده گواهی معتبر است و در زمان اعتبار سنجی گواهی توسط افراد دیگر مفهوم خاصی نداشته و نادیده گرفته می‌شود.

پسوند فایل‌های گواهی‌های‌ X.509[ویرایش]

گواهی‌های X.509 با توجه به محتویاتشان پسوند متفاوتی دارند که پراستفاده‌ترین آن‌ها به شرح زیر است.

توضیحات پسوند فایل
از این پسوند برای ذخیره فایل گواهی کلید عمومی با فرمت ASN.1 DER استفاده می‌شود. این نوع فایل متداول‌ترین فرمت برای ذخیره گواهی امضای دیجیتال است. .cer
از این پسوند برای ذخیره فایل گواهی کلید عمومی DER در غالب فرمت Base64 استفاده می‌شود. .pem
از این دو فرمت برای ذخیره‌ی لیست سریال گواهی‌های لغو شده(CRL) استفاده می‌شود. .p7b , .p7c
از این فرمت برای ذخیره‌ی گواهی کلید عمومی به همراه کلید خصوصی متناظر با آن، در یک فایل استفاده می‌شود. .p12 , .pfx


نمونه گواهی[ویرایش]

شکل زیر یک نمونه گواهی امضا شده توسط مرکز صدور گواهی زیرساخت ریشه ایران را نشان می‌دهد.

[Version]
V3
[Serial Number]
6107D34B000000000003
[Signature Algorithm]
sha1RSA(1.2.840.113549.1.1.5)
[Issuer]
CN=Islamic Republic of IRAN Root CA
Simple Name: Islamic Republic of IRAN Root CA
DNS Name: Islamic Republic of IRAN Root CA
[Not Before]
12/20/2010 3:13:00 AM
[Not After]
12/20/2026 3:23:00 AM
[Subject]
CN=Governmental General Intermediate CA, OU=Ministry of Commerce, OU=Iran Center for e-Commerce Development, OU=General Intermediate CA, O=I.R. Government, C=IR
Simple Name: Governmental General Intermediate CA
DNS Name: Governmental General Intermediate CA
[Algorithm]
RSA 2048 Parameters: 05 00
[Public Key]
30 82 01 0a 02 82 01 01 00 b6 e7 00 19 7b 40 fd cb 72 1a c8 38 67 f8 94 ca 54 3c d6 01 82 fc 52 8f 88 eb 21 24 00 44 54 7d a7 f5 5c 46 16 d2 fa 92 97 f5 e2 16 11 50 08 a4 f1 98 34 4a 14 d0 ff bc 92 20 38 62 c8 5c 21 e5 45 a6 02 03 b7 47 f3 5a a6 eb ea 3b a6 0b 4e 07 33 02 56 54 3c bf f5 0a 24 b4 7c 30 3b f6 f2 2b 2c 6b 0e 62 a9 07 d6 a8 44 ed ea 6a a7 54 10 67 4e 3a bd 95 b7 7e 92 5f b8 d3 69 73 0f 37 05 fa 51 5b fd bc 7d 33 b1 48 74 eb 90 ac 20 8b b5 b0 c6 d8 1c e9 aa 95 5a 97 2b f6 2b 92 29 d0 dd 50 ce 79 bc a5 32 99 b4 db 82 52 0e 64 78 48 0f b5 25 6d ec aa 6d 1e d0 d1 10 e9 dd d2 90 b0 c3 0c be 2f f1 69 c9 be 77 72 61 d8 52 2b 50 a7 c1 a3 3d b5 f1 92 72 0d 32 c7 06 19 21 2a 47 81 40 21 f6 a4 ee a7 2d 1f b1 35 07 96 d8 b3 ef e3 58 9f d8 f1 bc ef 00 4b f7 a9 ab 0d a1 57 9d c3 e6 31 02 03 01 00 01
[Extensions]

* Basic Constraints(2.5.29.19):
Subject Type=CA
Path Length Constraint=4

* Subject Key Identifier(2.5.29.14):
2b 8c 99 0b 8a d3 26 6d 06 a6 d6 7d c7 eb bd 0f e1 0d 6b 0b

* Key Usage(2.5.29.15):
Digital Signature, Certificate Signing, Off-line CRL Signing, CRL Signing (86)

* CA Version(1.3.6.1.4.1.311.21.1):
V0.0

* Certificate Policies(2.5.29.32):
[1]Certificate Policy:
Policy Identifier=2.16.364.101.1.3.1
[1,1]Policy Qualifier Info:
Policy Qualifier Id=CPS
Qualifier:
http://www.mocca.ir/repository/cps-gica.pdf

* Certificate Template Name(1.3.6.1.4.1.311.20.2):
SubCA

* Authority Key Identifier(2.5.29.35):
KeyID=fb 70 9f a6 ac ac 37 31 d7 1d 42 f9 fc 7d be 6e 7e c0 f9 74

* CRL Distribution Points(2.5.29.31):
[1]CRL Distribution Point
Distribution Point Name:
Full Name:
http://crl.rca.gov.ir/irica.crl

واژگان[ویرایش]

روش اعتبارسنجی مسیر گواهی certification path validation algorithm
زیرساخت کلید عمومی public key infrastructure
فیلد توسعه Extension Field
قیدهای پایه‌ایی Basic Constraints
گواهی کلید عمومی public key certificates
لیست گواهی‌های لغو شده certificate revocation lists

مخفف[ویرایش]

OID= Object Identifier
ASN.1= Abstract Syntax Notation One

منابع[ویرایش]