commit
3311cef85c
217
src/main/java/org/owasp/webgoat/lessons/ZipBomb.java
Normal file
217
src/main/java/org/owasp/webgoat/lessons/ZipBomb.java
Normal file
@ -0,0 +1,217 @@
|
||||
package org.owasp.webgoat.lessons;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Enumeration;
|
||||
import java.util.List;
|
||||
import java.util.zip.ZipEntry;
|
||||
import java.util.zip.ZipException;
|
||||
import java.util.zip.ZipFile;
|
||||
|
||||
import org.apache.commons.fileupload.FileItem;
|
||||
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
|
||||
import org.apache.commons.fileupload.servlet.ServletFileUpload;
|
||||
import org.apache.ecs.Element;
|
||||
import org.apache.ecs.ElementContainer;
|
||||
import org.apache.ecs.html.A;
|
||||
import org.apache.ecs.html.Form;
|
||||
import org.apache.ecs.html.IMG;
|
||||
import org.apache.ecs.html.Input;
|
||||
import org.apache.ecs.html.P;
|
||||
import org.owasp.webgoat.session.ECSFactory;
|
||||
import org.owasp.webgoat.session.WebSession;
|
||||
|
||||
/*******************************************************************************
|
||||
*
|
||||
*
|
||||
* This file is part of WebGoat, an Open Web Application Security Project
|
||||
* utility. For details, please see http://www.owasp.org/
|
||||
*
|
||||
* Copyright (c) 2002 - 20014 Bruce Mayhew
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it under
|
||||
* the terms of the GNU General Public License as published by the Free Software
|
||||
* Foundation; either version 2 of the License, or (at your option) any later
|
||||
* version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
||||
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
||||
* details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License along with
|
||||
* this program; if not, write to the Free Software Foundation, Inc., 59 Temple
|
||||
* Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Getting Source ==============
|
||||
*
|
||||
* Source for this application is maintained at https://github.com/WebGoat/WebGoat, a repository
|
||||
* for free software projects.
|
||||
*
|
||||
* For details, please see http://webgoat.github.io
|
||||
*
|
||||
* @author Jakub Koperwas of <a href="http://www.sages.com.pl">Sages</a>
|
||||
* @created October 31, 2014
|
||||
*/
|
||||
|
||||
public class ZipBomb extends LessonAdapter {
|
||||
public final static A SAGES_LOGO = new A().setHref(
|
||||
"http://www.sages.com.pl").addElement(
|
||||
new IMG("images/logos/sages.png").setAlt("Sages").setBorder(0)
|
||||
.setHspace(0).setVspace(0).setStyle("width:180px; height:60px"));
|
||||
|
||||
|
||||
protected Element createContent(WebSession s) {
|
||||
|
||||
|
||||
ElementContainer ec = new ElementContainer();
|
||||
|
||||
|
||||
if ("success".equalsIgnoreCase((String)s.get(ZIP_DOS))){
|
||||
System.out.println("final success");
|
||||
makeSuccess(s);
|
||||
}
|
||||
try {
|
||||
|
||||
ec.addElement(new P().addElement("Upload new File"));
|
||||
|
||||
Input input = new Input(Input.FILE, "myfile", "");
|
||||
ec.addElement(input);
|
||||
|
||||
Element b = ECSFactory.makeButton("Start Upload");
|
||||
ec.addElement(b);
|
||||
|
||||
|
||||
|
||||
} catch (Exception e) {
|
||||
s.setMessage("Error generating " + this.getClass().getName());
|
||||
e.printStackTrace();
|
||||
}
|
||||
|
||||
return ec;
|
||||
}
|
||||
|
||||
protected Category getDefaultCategory() {
|
||||
return Category.DOS;
|
||||
}
|
||||
|
||||
|
||||
public List<String> getHints(WebSession s) {
|
||||
List<String> hints = new ArrayList<String>();
|
||||
|
||||
hints
|
||||
.add("You can upload up to 2MB file at once,see what can you insert INTO the file");
|
||||
|
||||
return hints;
|
||||
|
||||
}
|
||||
|
||||
public String getInstructions(WebSession s) {
|
||||
String instructions = "";
|
||||
|
||||
|
||||
instructions = "Server accepts only ZIP files, \n"
|
||||
+ "extracts them after uploading, does something with them and deletes,"
|
||||
+ "\n it provides 20 MB temporal storage to handle all request \n"
|
||||
+ "try do perform DOS attack that consume all temporal storage with one request";
|
||||
|
||||
|
||||
return (instructions);
|
||||
}
|
||||
|
||||
private final static Integer DEFAULT_RANKING = new Integer(10);
|
||||
private static final String ZIP_DOS = "ZIP_DOS";
|
||||
|
||||
protected Integer getDefaultRanking() {
|
||||
return DEFAULT_RANKING;
|
||||
}
|
||||
|
||||
|
||||
|
||||
public String getTitle() {
|
||||
return ("ZipBomb");
|
||||
}
|
||||
|
||||
|
||||
public Element getCredits() {
|
||||
return super.getCustomCredits("", SAGES_LOGO);
|
||||
}
|
||||
|
||||
public void handleRequest(WebSession s) {
|
||||
File tmpDir=(File)s.getRequest().getServletContext().getAttribute("javax.servlet.context.tempdir");
|
||||
|
||||
try {
|
||||
if (ServletFileUpload.isMultipartContent(s.getRequest())) {
|
||||
|
||||
DiskFileItemFactory factory = new DiskFileItemFactory();
|
||||
factory.setSizeThreshold(500000);
|
||||
|
||||
ServletFileUpload upload = new ServletFileUpload(factory);
|
||||
|
||||
|
||||
List /* FileItem */items = upload.parseRequest(s.getRequest());
|
||||
|
||||
|
||||
java.util.Iterator iter = items.iterator();
|
||||
while (iter.hasNext()) {
|
||||
FileItem item = (FileItem) iter.next();
|
||||
|
||||
if (!item.isFormField()) {
|
||||
|
||||
File uploadedFile= new File(tmpDir, item.getName());
|
||||
|
||||
if (item.getSize() < 2000 * 1024) {
|
||||
if (item.getName().endsWith(".zip")) {
|
||||
item.write(uploadedFile);
|
||||
|
||||
long total = unzippedSize(uploadedFile);
|
||||
s.setMessage("File uploaded");
|
||||
if (total > 20 * 1024 * 1024) {
|
||||
s.add(ZIP_DOS, "success");
|
||||
System.out.println("success");
|
||||
makeMessages(s);
|
||||
}else{
|
||||
s.setMessage("I still have plenty of free storage on the server...");
|
||||
}
|
||||
|
||||
} else {
|
||||
s.setMessage("Only ZIP files are accepted");
|
||||
}
|
||||
} else {
|
||||
s.setMessage("Only up to 2 MB files are accepted");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
Form form = new Form(getFormAction(), Form.POST).setName("form")
|
||||
.setEncType("multipart/form-data");
|
||||
|
||||
form.addElement(createContent(s));
|
||||
|
||||
setContent(form);
|
||||
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace(System.out);
|
||||
}
|
||||
}
|
||||
|
||||
private long unzippedSize(File uploadedFile) throws ZipException,
|
||||
IOException {
|
||||
ZipFile zf = new ZipFile(uploadedFile);
|
||||
|
||||
long total = 0;
|
||||
Enumeration e = zf.entries();
|
||||
while (e.hasMoreElements()) {
|
||||
ZipEntry entry = (ZipEntry) e.nextElement();
|
||||
|
||||
total += entry.getSize();
|
||||
|
||||
}
|
||||
return total;
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
BIN
src/main/webapp/images/logos/sages.png
Normal file
BIN
src/main/webapp/images/logos/sages.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 6.3 KiB |
Loading…
x
Reference in New Issue
Block a user