HTTP.java 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. package de.tudarmstadt.informatik.hostage.protocol;
  2. import java.security.SecureRandom;
  3. import java.text.SimpleDateFormat;
  4. import java.util.ArrayList;
  5. import java.util.Calendar;
  6. import java.util.List;
  7. import java.util.Locale;
  8. import java.util.TimeZone;
  9. /**
  10. * HTTP protocol
  11. * @author Wulf Pfeiffer
  12. */
  13. public class HTTP implements Protocol<String> {
  14. public int getPort() {
  15. return 80;
  16. }
  17. public TALK_FIRST whoTalksFirst() {
  18. return TALK_FIRST.CLIENT;
  19. }
  20. public List<String> processMessage(String message) {
  21. List<String> response = new ArrayList<String>();
  22. request = message + request;
  23. if(!message.contains(version)){
  24. response.add(buildPacket(c505, ""));
  25. } else if(message.contains(get)) {
  26. response.add(buildPacket(c200, get));
  27. } else if(message.contains(head)) {
  28. response.add(buildPacket(c200, head));
  29. } else if(message.contains(trace)){
  30. response.add(buildPacket(c200, trace));
  31. } else if(message.contains(options)){
  32. response.add(buildPacket(c400, options));
  33. } else if(message.contains(post)){
  34. response.add(buildPacket(c200, post));
  35. } else if(message.contains(put)){
  36. response.add(buildPacket(c400, put));
  37. } else if(message.contains(delete)){
  38. response.add(buildPacket(c200, delete));
  39. } else if(message.contains(connect)){
  40. response.add(buildPacket(c400, connect));
  41. } else {
  42. response.add(buildPacket(c400, ""));
  43. }
  44. return response;
  45. }
  46. public boolean isClosed() {
  47. return true;
  48. }
  49. public boolean isSecure() {
  50. return false;
  51. }
  52. public Class<String> getType() {
  53. return String.class;
  54. }
  55. public String toString() {
  56. return "HTTP";
  57. }
  58. /**
  59. * Builds a html response that can be sent
  60. * @param code response code that was determined
  61. * @param type request type that was sent by the client
  62. * @return the html response
  63. */
  64. private String buildPacket(String code, String type) {
  65. String doc = "";
  66. if(type.equals(get)) doc = htmlDoc;
  67. else if(type.equals(head) || type.equals(delete)) doc = "";
  68. else if(type.equals(trace)) doc = request;
  69. else doc = errorHtmlPrefix + " " + code + errorHtmlSuffix;
  70. return version + " " + code + headerPrefix + doc.length() + headerSuffix + doc;
  71. }
  72. /**
  73. * Get the current time in html header format.
  74. * @return the formatted server time.
  75. */
  76. private String getServerTime() {
  77. Calendar calendar = Calendar.getInstance();
  78. SimpleDateFormat dateFormat = new SimpleDateFormat(
  79. "EEE, dd MMM yyyy HH:mm:ss z", Locale.US);
  80. dateFormat.setTimeZone(TimeZone.getTimeZone("GMT"));
  81. return dateFormat.format(calendar.getTime());
  82. }
  83. private String getQuote() {
  84. // String[] sources = new String[]{"djxmmx.net", "ota.iambic.com", "alpha.mike-r.com", "electricbiscuit.org"};
  85. // SecureRandom rndm = new SecureRandom();
  86. // StringBuffer sb = new StringBuffer();
  87. // try {
  88. // Socket client = new Socket(sources[rndm.nextInt(4)], 17);
  89. // BufferedReader in = new BufferedReader(new InputStreamReader(client.getInputStream()));
  90. // while(!in.ready());
  91. // while(in.ready()) {
  92. // sb.append(in.readLine());
  93. // }
  94. // in.close();
  95. // client.close();
  96. // } catch (Exception e) {
  97. // e.printStackTrace();
  98. // }
  99. // return sb.toString();
  100. return "";
  101. }
  102. private String[][][] possibleVersions = {
  103. {{"Apache/2.0."},{"28","32","35","36","39","40","42","43","44","45","46","47","48","49","50","51","52","53","54","55","58","59","61","63","64","65"}},
  104. {{"Apache/2.2."},{"0","2","3","4","6","8","9","10","11","12","13","14","15","16","17","18","19","20","21","22","23","24","25"}},
  105. {{"Apache/2.3."},{"4","5","6","8","10","11","12","14","15","16"}},
  106. {{"Apache/2.4."},{"1","2","3","4","6"}}
  107. };
  108. private SecureRandom rndm = new SecureRandom();
  109. private int majorVersion = rndm.nextInt(3);
  110. private final String serverVersion = possibleVersions[majorVersion][0][0] + possibleVersions[majorVersion][1][rndm.nextInt(possibleVersions[majorVersion][1].length)];
  111. //html header pre and suffix
  112. private final String headerPrefix =
  113. "Date: " + getServerTime() + "\r\n" +
  114. "Server: " + serverVersion + " \r\n" +
  115. "Vary: Accept-Encoding\r\n" +
  116. "Content-Length: ";
  117. private String headerSuffix =
  118. "\r\n" +
  119. "Keep-Alive: timeout=5, max=100\r\n" +
  120. "Connection: Keep-Alive\r\n" +
  121. "Content-Type: text/html\r\n" +
  122. "\r\n";
  123. //html website
  124. private String htmlDoc =
  125. "<!doctype html>\n" +
  126. "<html lang=\"en\">\n" +
  127. "<head>\n" +
  128. "<meta charset=\"UTF-8\">\n" +
  129. "<title>" + getQuote() + "</title>\n" +
  130. "</head>\n" +
  131. "</html>";
  132. //html error pre and suffix
  133. private String errorHtmlPrefix =
  134. "<!doctype html>\n" +
  135. "<html lang=\"en\">\n" +
  136. "<head>\n" +
  137. "<meta charset=\"UTF-8\">\n" +
  138. "<title>";
  139. private String errorHtmlSuffix =
  140. "</title>\n" +
  141. "</head>\n" +
  142. "</html>";
  143. /** Whole request that was sent by the client */
  144. private String request = "";
  145. private String version = "HTTP/1.1";
  146. //request codes
  147. private String options = "OPTIONS";
  148. private String get = "GET";
  149. private String head = "HEAD";
  150. private String post = "POST";
  151. private String put = "PUT";
  152. private String delete = "DELETE";
  153. private String trace = "TRACE";
  154. private String connect = "CONNECT";
  155. private String c200 = "200 OK\r\n";
  156. private String c400 = "400 Bad Request\r\n";
  157. private String c505 = "505 HTTP Version not supported\r\n";
  158. }