HTTPS.java 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. package de.tudarmstadt.informatik.hostage.protocol;
  2. import java.security.KeyStore;
  3. import javax.net.ssl.KeyManagerFactory;
  4. import javax.net.ssl.SSLContext;
  5. import de.tudarmstadt.informatik.hostage.HoneyService;
  6. /**
  7. * HTTPS protocol
  8. * @author Wulf Pfeiffer
  9. */
  10. public class HTTPS extends HTTP implements SSLProtocol {
  11. @Override
  12. public int getDefaultPort() {
  13. return 443;
  14. }
  15. @Override
  16. public boolean isSecure() {
  17. return true;
  18. }
  19. @Override
  20. public String toString() {
  21. return "HTTPS";
  22. }
  23. @Override
  24. public SSLContext getSSLContext() {
  25. String ksName = "https_cert.bks";
  26. char ksPass[] = "password".toCharArray();
  27. KeyStore ks;
  28. KeyManagerFactory kmf = null;
  29. try {
  30. ks = KeyStore.getInstance(KeyStore.getDefaultType());
  31. ks.load(HoneyService.getContext().getAssets().open(ksName), ksPass);
  32. kmf = KeyManagerFactory.getInstance(KeyManagerFactory
  33. .getDefaultAlgorithm());
  34. kmf.init(ks, ksPass);
  35. } catch (Exception e) {
  36. e.printStackTrace();
  37. }
  38. SSLContext sslcontext = null;
  39. try {
  40. sslcontext = SSLContext.getInstance("SSLv3");
  41. sslcontext.init(kmf.getKeyManagers(), null, null);
  42. } catch (Exception e) {
  43. e.printStackTrace();
  44. }
  45. return sslcontext;
  46. }
  47. }