Issue 42
git-svn-id: http://webgoat.googlecode.com/svn/trunk/webgoat@470 4033779f-a91e-0410-96ef-6bf7bf53c507
This commit is contained in:
		| @ -65,7 +65,7 @@ public class HttpSplitting extends SequentialLessonAdapter | |||||||
| 		// Setting a special action to be able to submit to redirect.jsp | 		// Setting a special action to be able to submit to redirect.jsp | ||||||
| 		Form form = new Form(s.getRequest().getContextPath() + "/lessons/General/redirect.jsp?" + "Screen=" + String.valueOf(getScreenId()) | 		Form form = new Form(s.getRequest().getContextPath() + "/lessons/General/redirect.jsp?" + "Screen=" + String.valueOf(getScreenId()) | ||||||
|  				+ "&menu=" + getDefaultCategory().getRanking().toString(), Form.POST).setName("form").setEncType(""); |  				+ "&menu=" + getDefaultCategory().getRanking().toString(), Form.POST).setName("form").setEncType(""); | ||||||
|  | 		 | ||||||
| 		form.addElement(createContent(s)); | 		form.addElement(createContent(s)); | ||||||
|  |  | ||||||
| 		setContent(form); | 		setContent(form); | ||||||
| @ -86,25 +86,15 @@ public class HttpSplitting extends SequentialLessonAdapter | |||||||
|  |  | ||||||
| 			if (lang.length() != 0 && fromRedirect.length() != 0) | 			if (lang.length() != 0 && fromRedirect.length() != 0) | ||||||
| 			{ | 			{ | ||||||
| 				// Split by the line separator line.separator is platform independant | 				 | ||||||
| 				String lineSep = System.getProperty("line.separator"); | 	 | ||||||
| 				String[] arrTokens = lang.toString().toUpperCase().split(lineSep); | 				String[] arrTokens = lang.toString().toUpperCase().split("\r\n"); | ||||||
|  |  | ||||||
| 				// Check if the user ended the first request and wrote the second malacious reply | 				// Check if the user ended the first request and wrote the second malicious reply | ||||||
|  | 				if (arrTokens.length > 1) | ||||||
| 				if (Arrays.binarySearch(arrTokens, "CONTENT-LENGTH: 0") >= 0 |  | ||||||
| 						&& Arrays.binarySearch(arrTokens, "HTTP/1.1 200 OK") >= 0) |  | ||||||
| 				{ | 				{ | ||||||
| 					HttpServletResponse res = s.getResponse(); | 					HttpServletResponse res = s.getResponse(); | ||||||
| 					res.setContentType("text/html"); | 					res.setContentType("text/html"); | ||||||
| 					PrintWriter out = new PrintWriter(res.getOutputStream()); |  | ||||||
| 					String message = lang.substring(lang.indexOf("<html>")); |  | ||||||
|  |  | ||||||
| 					out.print(message); |  | ||||||
| 					out.flush(); |  | ||||||
| 					out.close(); |  | ||||||
|  |  | ||||||
| 					getLessonTracker(s).setStage(2); |  | ||||||
|  |  | ||||||
| 					StringBuffer msg = new StringBuffer(); | 					StringBuffer msg = new StringBuffer(); | ||||||
|  |  | ||||||
| @ -115,6 +105,10 @@ public class HttpSplitting extends SequentialLessonAdapter | |||||||
| 					msg.append("the reply and replace it with a 304 reply."); | 					msg.append("the reply and replace it with a 304 reply."); | ||||||
|  |  | ||||||
| 					s.setMessage(msg.toString()); | 					s.setMessage(msg.toString()); | ||||||
|  | 					getLessonTracker(s).setStage(2); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 					//makeSuccess(s); | ||||||
|  |  | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| @ -189,11 +183,11 @@ public class HttpSplitting extends SequentialLessonAdapter | |||||||
| 			String fromRedirect = s.getParser().getStringParameter(REDIRECT, ""); | 			String fromRedirect = s.getParser().getStringParameter(REDIRECT, ""); | ||||||
|  |  | ||||||
| 			if (lang.length() != 0 && fromRedirect.length() != 0) | 			if (lang.length() != 0 && fromRedirect.length() != 0) | ||||||
| 			{ | 			{				 | ||||||
| 				String lineSep = System.getProperty("line.separator"); | 				String lineSep = "\r\n"; | ||||||
| 				String dateStr = lang.substring(lang.indexOf("Last-Modified:") + "Last-Modified:".length(), lang | 				String dateStr = lang.substring(lang.indexOf("Last-Modified:") + "Last-Modified:".length(), lang | ||||||
| 						.indexOf(lineSep, lang.indexOf("Last-Modified:"))); | 						.indexOf(lineSep, lang.indexOf("Last-Modified:"))); | ||||||
| 				if (dateStr.length() != 0) | 				if (dateStr.length() > 0) | ||||||
| 				{ | 				{ | ||||||
| 					Calendar cal = Calendar.getInstance(); | 					Calendar cal = Calendar.getInstance(); | ||||||
|  |  | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user