HTTPS.java 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. package de.tudarmstadt.informatik.hostage.protocol;
  2. import java.security.KeyStore;
  3. import java.util.ArrayList;
  4. import java.util.List;
  5. import javax.net.ssl.KeyManagerFactory;
  6. import javax.net.ssl.SSLContext;
  7. import de.tudarmstadt.informatik.hostage.ui.MainActivity;
  8. /**
  9. * HTTPS protocol
  10. * @author Wulf Pfeiffer
  11. */
  12. public class HTTPS implements SSLProtocol<String> {
  13. @Override
  14. public int getPort() {
  15. return 443;
  16. }
  17. @Override
  18. public TALK_FIRST whoTalksFirst() {
  19. return TALK_FIRST.CLIENT;
  20. }
  21. private String lastMessage;
  22. @Override
  23. public List<String> processMessage(String message) {
  24. if(message != null)
  25. lastMessage = message;
  26. List<String> response = new ArrayList<String>();
  27. request = message + request;
  28. if(!message.contains(version)){
  29. response.add(buildPacket(c505, ""));
  30. } else if(message.contains(get)) {
  31. response.add(buildPacket(c200, get));
  32. } else if(message.contains(head)) {
  33. response.add(buildPacket(c200, head));
  34. } else if(message.contains(trace)){
  35. response.add(buildPacket(c200, trace));
  36. } else if(message.contains(options)){
  37. response.add(buildPacket(c400, options));
  38. } else if(message.contains(post)){
  39. response.add(buildPacket(c400, post));
  40. } else if(message.contains(put)){
  41. response.add(buildPacket(c400, put));
  42. } else if(message.contains(delete)){
  43. response.add(buildPacket(c400, delete));
  44. } else if(message.contains(connect)){
  45. response.add(buildPacket(c400, connect));
  46. } else {
  47. response.add(buildPacket(c400, ""));
  48. }
  49. return response;
  50. }
  51. @Override
  52. public boolean isClosed() {
  53. return true;
  54. }
  55. @Override
  56. public boolean isSecure() {
  57. return true;
  58. }
  59. @Override
  60. public Class<String> getType() {
  61. return String.class;
  62. }
  63. @Override
  64. public String toString() {
  65. return "HTTPS";
  66. }
  67. @Override
  68. public String getRequestContent() {
  69. return lastMessage;
  70. }
  71. @Override
  72. public SSLContext getSSLContext() {
  73. String ksName = "https_cert.bks";
  74. char ksPass[] = "password".toCharArray();
  75. KeyStore ks;
  76. KeyManagerFactory kmf = null;
  77. try {
  78. ks = KeyStore.getInstance(KeyStore.getDefaultType());
  79. ks.load(MainActivity.getContext().getAssets().open(ksName), ksPass);
  80. kmf = KeyManagerFactory.getInstance(KeyManagerFactory
  81. .getDefaultAlgorithm());
  82. kmf.init(ks, ksPass);
  83. } catch (Exception e) {
  84. e.printStackTrace();
  85. }
  86. SSLContext sslcontext = null;
  87. try {
  88. sslcontext = SSLContext.getInstance("SSLv3");
  89. sslcontext.init(kmf.getKeyManagers(), null, null);
  90. } catch (Exception e) {
  91. e.printStackTrace();
  92. }
  93. return sslcontext;
  94. }
  95. /**
  96. * Builds a html response that can be sent
  97. * @param code response code that was determined
  98. * @param type request type that was sent by the client
  99. * @return the html response
  100. */
  101. private String buildPacket(String code, String type) {
  102. String doc = "";
  103. if(type.equals(get)) doc = htmlDoc;
  104. else if(type.equals(head)) doc = "";
  105. else if(type.equals(trace)) doc = request;
  106. else doc = errorHtmlPrefix + code + errorHtmlSuffix;
  107. return version + code + headerPrefix + doc.length() + headerSuffix + doc;
  108. }
  109. /** Whole request that was sent by the client */
  110. private String request = "";
  111. private String version = "HTTP/1.1";
  112. //request codes
  113. private String options = "OPTIONS";
  114. private String get = "GET";
  115. private String head = "HEAD";
  116. private String post = "POST";
  117. private String put = "PUT";
  118. private String delete = "DELETE";
  119. private String trace = "TRACE";
  120. private String connect = "CONNECT";
  121. //response codes
  122. private String c200 = " 200 OK\r\n";
  123. private String c400 = " 400 Bad Request\r\n";
  124. private String c505 = " 505 HTTP Version not supported\r\n";
  125. //html header pre and suffix
  126. private String headerPrefix =
  127. "Date: Mon, 01 Jul 2013 18:27:55 GMT\r\n" +
  128. "Server: Apache/2.2.22 (Debian)\r\n" +
  129. "Vary: Accept-Encoding\r\n" +
  130. "Content-Length: ";
  131. private String headerSuffix =
  132. "\r\n" +
  133. "Keep-Alive: timeout=5, max=100\r\n" +
  134. "Connection: Keep-Alive\r\n" +
  135. "Content-Type: text/html\r\n" +
  136. "\r\n";
  137. //html website
  138. private String htmlDoc =
  139. "<!doctype html>\n" +
  140. "<html lang=\"en\">\n" +
  141. "<head>\n" +
  142. "<meta charset=\"UTF-8\">\n" +
  143. "<title>Test successful</title>\n" +
  144. "</head>\n" +
  145. "<body>\n" +
  146. "<h1>Test successful</h1>\n" +
  147. "<p>Congratulations.</p>\n" +
  148. "</body>\n" +
  149. "</html>";
  150. //html error pre and suffix
  151. private String errorHtmlPrefix =
  152. "<!doctype html>\n" +
  153. "<html lang=\"en\">\n" +
  154. "<head>\n" +
  155. "<meta charset=\"UTF-8\">\n" +
  156. "<title>";
  157. private String errorHtmlSuffix =
  158. "</title>\n" +
  159. "</head>\n" +
  160. "<body>\n" +
  161. "</body>\n" +
  162. "</html>";
  163. }