Ana içeriğe atla

Tomcat SSL Ayarları ve SSL İşlemleri

Aşağıdaki belge size sisteminizde kurulu olan Tomcat'e nasıl SSL ekleyeceğinizi ve geliştirme amaçlı nasıl ssl sertifikası alabileceğinizi açıklamayı hedeflemiştir. Geliştirme amaçlı olduğu için gerçek bir ssl sertifikası kullanılmayacak ve gerçek bir ssl gibi çalışmayacaktır. Amaç geliştiriciye ssl ile geliştirme imkanı sağlamaktır.

Ortam

Bu yazı windows sistemler baz alınarak hazırlanmıştır. Fakat Unix/Linux sistemlerinde de aynen çalışması gerekir.
Eğer Tomcat kendi başına çalışmıyorda başka bir web sunucusu arkasında çalışıyorsa Tomcat üzerinde herhangi bir işlem yapmaya gerek yoktur. Fakat kendi başına çalışan Tomcat sürümü kullanıyorsanız aşağıdaki ayarları yapmanız gerekecektir. Bu yazıyı yazarken Tomcat 6.0.16 sürümünü kullanmaktayım.

Not

Bu yazıyı çalışırken hızlı hızlı yazdım. Dolayısı ile bazı hatalar içeriyor olabilir.

Genel Olarak SSL

Secure Socket Layer (Güvenli Soket Katmanı) adı verilen bu teknoloji sunucu ile istemci arasında verilerin güvenli bir şekilde gönderilmesini sağlar. Basitçe bakacak olursak bir taraftan diğer tarafa gidecek olan veriler önce şifrelenir, soket üzerinden gönderilir ve verinin ulaştığı yerde şifresi çözülerek ulaşım sağlanır.

Tomcat Kurulumu

Eğer daha önceden kurmadıysanız aşağıdaki bileşenleri kurmanız gerekmektedir. Bu bileşenler tomcat'in ssl ile çalışması için gereklidir.

Apache Tomcat Native http://tomcat.apache.org/native-doc/
indirmek için http://tomcat.heanet.ie/native/1.1.12/binaries/win32/tcnative-1.dll
ve http://tomcat.heanet.ie/native/1.1.12/binaries/win32/openssl.exe
Bu iki dosyayı %CATALINA_HOME%\bin altına kopyalayın. openssl.exe dosyasını kopyalamanız gerekmeyebilir. Ben test etmedim.

Apache Portable Runtime http://apr.apache.org/
indirmek için http://www.ip97.com/apache.org/apr/binaries/win32/apr-all-1.2.12-win32-x86-msvcrt60.zip
Bu klasörü uygun gördüğünüz bir yere açın ve içerisindeki bin klasörünü path sistem değişkenine ekleyin.

Ayrıca Open SSL kurulumunu indirin, kurun ve lib\VC klasörünü path sistemdeğişkenine ekleyin. Örneğin benim sistemimde

c:\OpenSSL\lib\VC

şeklindedir.

Keystore Dosyası Oluşturmak

Windows sistemlerde

"%JAVA_HOME%\bin\keytool" -genkey -alias tomcat -keyalg RSA



Unix sistemlerde

$JAVA_HOME/bin/keytool -genkey -alias tomcat -keyalg RSA



komutlarını komut satırından çalıştırın. Size bir dizi soru soracak. Bu sorulardan ilki ssl ile işaretlemek istediğiniz alanadı olmalı. "What is your first and last name?" sorusuna vereceğiniz cevap alanadi.com olduğu zaman www.alanadi.com çalışmaz. Eğer *.alanadi.com şeklinde çalışmak istiyorsanız wildcard ssl kullanmanız gerekidir. Biz geliştirme amacı ile kullanacağımıza göre bizim alan adımız büyük ihtimalle localhost olacaktır.

Bu işlem sonucunda user klasörü altında .keystore adında bir dosya oluşması gerekli. İsterseniz dosya adını kendiniz belirleyebilir, istediğiniz klasöre kaydedebilirsiniz. Ben bu yöntemi kullanıyorum.

"%JAVA_HOME%\bin\keytool" -genkey -alias tomcat -keyalg RSA -keystore ./tomcat_ca


komutunu çalıştırdığınızda komutu çalıştırdığınız yerde tomcat_ca adında bir dosya oluşması gereklidir. Ben bu klasörü tomcat içerisindeki conf klasörü olarak belirledim.

Şimdi gerekli olan sertifika dosyamızı oluşturmuş olduk. Eğer geliştirme amaçlı değilde gerçek bir ssl sistemi kuruyor olsaydık o zaman ssl sağlayıcı bir firmadan ayrıca hizmet almamız gerekirdi.

Tomcat Ayarları

%CATALINA_HOME%\conf\server.xml dosyasında yeni bir Connector yaratmamız gerekli. Eğer Tomcat'i varsayılan ayarları ile kullanıyorsanız Tomcat, istemci ile 8080 portundan konuşuyor demektir. Bu ayar server.xml dosyası içerisinde bulunmaktadır. Varsayılan olarak aşağıdaki şekilde gelmektedir.

connectionTimeout="20000"
redirectPort="8443" />

Bu girişten sonra yorum satırına alınmış olarak 8443 numaralı portu ayarlayan Connector girişi bulunmaktadır. Yorum satırı aynen dursun. Biz aşağıdaki Connector girişini sonrasına yapıştıralım.

port="8443"
enableLookups="true" disableUploadTimeout="true"
acceptCount="100" maxThreads="200"
scheme="https" secure="true" SSLEnabled="true"
keystoreFile="conf/tomcat_ca" keystorePass="Sifre"
clientAuth="false" sslProtocol="TLS"/>

Yukarıdaki girişte keystorePass niteliğine keystore dosyanızı oluştururken vermiş olduğunuz şifreyi girin.

Sonuç

Artık Tomcat istemci ile ssl üzerinden konuşmaya hazır. Test etmek için

https://localhost:8443/

adresine girebilirsiniz.

Faydalanılan Kaynaklar

http://tomcat.apache.org/tomcat-6.0-doc/ssl-howto.html
http://www.nabble.com/SSL-SetAllPropertiesRule-warning-and-error-td15432321.html

Yorumlar

Bu blogdaki popüler yayınlar

Aşkı Anlatan Engüzel Hikayelerden Pervane İle Mum (2001-08-27 Cumartesi)

Pervane, mum alevinin çevresinde mıknatısi bir güç ile döner durur. Tıpkı sevgilinin mahallesinden ayrılamayan aşık gibi. O kadar ki, gittikçe daha fazla cesaretlenerek daha yakın hareket etmeye, dönerken çizdiği çemberin yarıçapını daraltmaya başlar. Böylece cesareti şevkini artırır, şevki arttıkça da cesaret bulur. Tıpkı sevgilisine yaklaştıkça daha fazla yaklaşmak için bahaneler arayan aşık gibi. Öyle ki, pervane birkaç zaman sonra muma iyice yaklaşmış olur. Bu sefer de onun gerçeğini anlamak ister ve kendısiyle onu aynileştirmek için dönüş çemberini iyice daraltır. Bu da, tıpkı sevgilisine yaklaşınca ona dokunmak, onunla konuşmak, onun sıcaklığını duymak isteyen aşığın haline benzer. Ve nihayet pervane mumun ateşine kanadını uzatır/kaptırır ve yanmanın ne demek olduğunu hakka'l-yakin öğrenir. Önce duyarak/okuyarak, sonra da görerek edindiği yanış bilgisi bu sefer gerçeklik kazanır ve aşk ateşi pervanenin narin vücudunu küle döndürür. Tıpkı aşığın aşk ateşiyle yanıp yakılması v...

MacOSX Program Kaldırmak

MacOSX için karşımıza iki çeşit kurulum (install) dosyası çıkıyor. Biri dmg uzantılı dosyalar (aslında dmg uzantılı dosyalar kurulum dosyaları değildir, disk imajı saklarlar) diğeri ise pkg uzantılı dosyalar. dmg uzantılı dosyalar için bir beis yok, onları açtıktan sonra içinden çıkan dosyayı alıp Application klasörüne sürüklüyoruz kurulum gerçekleşiyor, kaldırmak istediğimizde ise Application klasöründen siliyoruz ve iş bitiyor. Gerçekten basit ve güzel. Fakat her program bununla yetinemiyor ve bunun bir çok nedeni olabilir. Neticede pkg uzantılı kurulum dosyaları sisteminizin değişik yerlerine değişik dosyalar kopyalıyorlar. Windows'taki gibi registery yok ve ben bundan çok memnunum. Registery için bir çok performans problemi yatatıldığını biliyoruz, her açılışta ve kapanışta yapılan taramalar v.b.. Aynı zamanda uninstall için gereken sistem de MacOSX'te yok. Dolayısı ile bir programı kaldırmak istediğimizde pkg kurulum dosyasını nereye ne yazdığını bilmemiz gerekir. Bu bil...

Apache 2.2.17 ile Php 5.2.17 Kurulum Problemi (2011-01-25)

Apache'yi kurdunuz, ardından php'yi de Apache'nin conf klasörünü göstererek (httpd.conf dosyasını modifiye etmesi için) extension'ları ile beraber kurdunuz. Apache'nin start tuşuna basınca sunucu(server)'ın çalışmasını bekliyorsunuz. Çok beklersiniz!! İlk olarak httpd.conf dosyasına (genelde sonuna ekliyor) php'nin eklemelerine bakıyorsunuz. Path bilgileri girilmemiş. #BEGIN PHP INSTALLER EDITS - REMOVE ONLY ON UNINSTALL PHPIniDir "" LoadModule php5_module "php5apache2_2.dll" #END PHP INSTALLER EDITS - REMOVE ONLY ON UNINSTALL Bu satırları kurulum yaptığınız path (yol) bilgileri ile güncelliyorsunuz. #BEGIN PHP INSTALLER EDITS - REMOVE ONLY ON UNINSTALL PHPIniDir "c:/webapps/php" LoadModule php5_module "c:/webapps/php/php5apache2_2.dll" #END PHP INSTALLER EDITS - REMOVE ONLY ON UNINSTALL Bu değişikliği yaptıktan sonra Apache'nin çalışacağını düşünüyorsunuz normal olarak. Ama heyhat! çalışmıyor. Apac...