قسمت قبلی: من یک جاواکار نیستم!
در این قسمت، به عنوان ادامهای بر مباحث پیشین، ابزارهایی که از آغاز به نوشتن یک اپلت تا نصب آن روی کارت و ارتباط با آن نیاز است را معرفی میکنیم. در یک دید کلّی، ابزارهای مورد نیاز به دو دسته تقسیم میشوند:
1- سخت افزار:
طبیعتا برای این که کارت بتواند داده ای از سمت رایانه دریافت کند یا داده ای به آن ارسال کند، نیازمند سخت افزاری است که "کارت خوان" (Card Reader) نامیده میشود. نکتهی جالب توجه اینجاست که دستگاهی به نام "کارت نویس" (Card Writer) نداریم و همان کارتخوان هر دو عمل نوشتن و خواندن را انجام میدهد. بدیهتا، کارتخوان کارتهای تماسی با کارتخوان کارتهای غیر تماسی متفاوت است و هنگام خرید باید این را مد نظر قرار دهیم که قرار است با چه نوع کارتی کار کنیم. ACR38 و ACR122U دو نمونه کارتخوان به ترتیب برای کارت های تماسی و کارتهای غیرتماسی اند. همچنین ممکن است هنگام خرید کارتخوان، دستگاه هایی به نام Encoder و Decoder نیز به شما پیشنهاد شوند، که هیچ نیازی به آن ندارید. در واقع، این دو دستگاه برای ارتباط با کارتهای مغناطیسی (کارتهای با نوار مشکی- مانند کارتهای بانکی) استفاده میشوند. کارت های مغناطیسی بر خلاف کارتهای الکترونیکی تراشه دار، برای خواندن و نوشتن به دو دستگاه متفاوت نیاز دارند. دستگاهی که برای خواندن محتویات کارتهای مغناطیسی استفاده میشود Decoder و دستگاهی که برای نوشتن روی این کارتها استفاده میشود، Encoder نام دارد.
شایان ذکر است که الزامی برای جدا بودن کارتخوان کارت های تماسی و کارتخوان کارت های غیر تماسی از یک دیگر وجود ندارد؛ یعنی هم کارتخوان هایی موجود است که فقط یک واسط را پشتیبانی میکنند و هم کارتخوان هایی وجود دارند دارای دو واسط ارتباطی اند. در مورد Encoder و Decoder هم به همین صورت است؛ یعنی هم به صورت مجزا و هم به صورت یک مجموعهی واحد به فروش میرسند.
2- نرم افزار:
بحث در مورد نرم افزارهای مورد نیاز در زمینهی کارتهای هوشمند را با دو مثال متفاوت آغاز میکنیم:
اگر دانشجوی الکترونیک باشید، حتما تجربهی کار با میکروکنترلرها را در پروندهی خود خواهید داشت. برای عملی کردن یک پروژهی سادهی خواندن اطلاعات یک سنسور و ارسال به پورت سریال رایانه، شما به سه مجموعه نرم افزار نیاز خواهید داشت:
- نرم افزاری که در آن برنامهی مورد نظر را بنویسید (مانند Code vision، Bascom یا AVR Studio برای میکروهای AVR).
- نرم افزاری که به وسیلهی آن فایل ساخته شده را به میکرو منتقل کنید (مانند ProgISP یا Pony Prog).
- نرم افزاری که به وسیلهی آن داده های میکرو را از پورت سریال دریافت کنید (مانند Terminal یا Hyper Terminal یا Termite).
و اگر دانشجوی نرم افزار باشید و تجربهی توسعه ی یک صفحه ی وب را داشته باشید هم میدانید برای انجام یک پروژه ی طراحی ساده حداقل به سه دسته ابزار زیر نیاز دارید:
- نرم افزاری که در آن کد برنامه/صفحه ی خود را مینویسید (مانند PHP Storm یا PyCharm).
- نرم افزاری که به وسیله ی آن برنامه/صفحه ی نوشته شده را به Host(فضای روی اینترنت) منتقل میکنید (مانند Git، FileZila یا Free FTP).
- نرم افزاری که با صفحه وب نوشته شده ارتباط برقرار میکنید (مانند Chrome, FireFox)
خب، در مورد کارت هوشمند هم [که در واقع یک میکرو کنترلر است] روال به همین صورت بالاست. یعنی شما به سه مجموعه نرم افزار مختلف برای نوشتن اپلت، بارگذاری و نصب اپلت و ارتباط با اپلت نیاز دارید. و مجددا همانطور که در مثال های بالا، نرم افزارهای چند گروه میتوانند به صورت یک Package در یک ابزار ارائه شوند، در کارت هوشمند هم این سه دسته ابزار میتوانند در یک بسته ارائه گردند. در زیر به صورت خلاصه نرم افزارهای موجود برای هر گروه را نام میبریم و در خلال پست های بعدی به صورت عملی با هر کدام آشنا خواهیم شد:
نوشتن اپلت:
- Eclipse + JDK + Eclipse-JCDE + JCDK
- Netbeans + JDK
- JCIDE + JDK + JCDK
بارگذاری و نصب اپلت:
- GlobalPlatformPro (This is a tool! Don't confuse it with the Global Platform Standard that I mentioned in previous posts)
- JCManager
- PyAPDUTool
- GPShell
ارتباط با اپلت ها:
- OpenSCTool
- PyAPDUTool
- Your Reader SDK Tools
- Python library that is named "PySCard"
- Java package that is named "javax.smartcardio" (I think it is deprecated and is not available in JDK 1.7 and newer versions)
- C/C++ library that is named "winscard" (:-?)
نکته: شما در هر کدام از مجموعه های بالا تنها به یک ابزار نیاز دارید و بسته به این که با کدام یک ارتباط بهتری برقرار میکنید، در آینده یکی را انتخاب خواهید کرد. لازم به ذکر است که همانگونه که پیشتر بیان شد ابزارهایی نیز ارائه شده اند که نرم افزارهای هر سه مجموعه را در یک Package گرد آورده اند، لکن از آنجا که غالب آنها یا به خاطر تحریم یا بنا به دلایلی از قبیل داشتن مشتری های حقوقی (و نه حقیقی) و انحصاری در دسترس نیستند یا به صورت رایگان نمیباشند، در این مجموعه در مورد آن ها صحبتی نخواهیم کرد (احتمالا). به عنوان مثال JCOP Tools و Gemalto Developer Suite دو نرم افزاری هستند که به ترتیب توسط شرکت NXP (یکی از بزرگترین تولیدکنندگان تراشه های کارت هوشمند) و شرکت Gemalto (یکی از بزرگترین تولیدکنندگان سیم کارتها) ارائه شده اند و متشکل از تعداد زیادی پلاگین اند که روی هسته ی Eclipse سوار شده اند.
سوال: Netbeans یا Eclipse؟
جواب: هر دو! پاسخ به این سوال ارتباط زیادی با نسخهی جاواکارتی که قرار است با آن کار کنید دارد. از آنجا که Eclipse به صورت پیشفرض قابلیتی برای افزودن JCDK به آن ندارد، ما ناگریز باید از یک پلاگین استفاده کنیم (Eclipse-JCDE) و از آنجا که این پلاگین به صورت عادی تنها با نسخهی JCDK 2.2.2 و با کمی ترفند با نسخه های پایین تر از این ورژن کار میکند، پس برای کار با کارتهای نسخهی 2.2.2 و قبل از آن، Eclipse را انتخاب میکنیم. در مقابل، نرم افزار Netbeans به صورت پیشفرض با نسخهی JCDK 3.0.1 Classic & Connected ارائه میشود و چنانچه ما برنامه ی برای نوشتن روی کارتهای نسخهی 3 و بالاتر داریم، از این محیط برنامه نویسی استفاده خواهیم کرد.
"A ship is safe in harbor, but that’s not what ships are for." | William G.T. Shedd