Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cdaller/security_taint_propagation
Java taint propagation for java. Define tainted sources, sanitizer methods and sinks via aspects.
https://github.com/cdaller/security_taint_propagation
Last synced: about 2 months ago
JSON representation
Java taint propagation for java. Define tainted sources, sanitizer methods and sinks via aspects.
- Host: GitHub
- URL: https://github.com/cdaller/security_taint_propagation
- Owner: cdaller
- Created: 2012-09-14T11:32:23.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2018-10-11T07:28:40.000Z (over 6 years ago)
- Last Synced: 2024-08-05T17:26:43.624Z (6 months ago)
- Language: Java
- Homepage:
- Size: 220 KB
- Stars: 26
- Watchers: 5
- Forks: 10
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Security: security_taint_extension/.classpath
Awesome Lists containing this project
- awesome-hacking-lists - cdaller/security_taint_propagation - Java taint propagation for java. Define tainted sources, sanitizer methods and sinks via aspects. (Java)
README
# Dynamic Security Taint Propagation in Java via Java Aspects
This project defines some java aspects that allow to follow tainted strings from a
source to a sink to find security leaks in software (SQL-Injection, Cross-Site-Scripting (XSS)).Therefore the ```java.lang.String``` class is extended with a "tainted" flag. This flag is
set on all strings that come from defined sources (e.g. ```HttpServletRequest.getParameter()```)
and passed to all strings that use the tainted string (e.g. ```String foo = "foo" + tainted;```
results in tainted foo). When a tainted string reaches a sink, the system can react in
different ways (log message, throw exception, ...).Some "cleaner" or "sanitizer" methods can be used to remove the tainted flag. E.g. when
you want to protect your application from XSS, a cleaner method would escape all
characters that may be interpreted by the browser (especially the "<" sign).Christof Dallermassl (christof at dallermassl dot at)
## Background knowledge
I found some papers about this topic:
* [Vivek Haldar, Deepak Chandra, Michael Franz: Dynamic Taint Propagation for Java](http://www.acsac.org/2005/papers/45.pdf)
* [A presentation at blackhat security conference](http://www.blackhat.com/presentations/bh-dc-08/Chess-West/Presentation/bh-dc-08-chess-west.pdf)
* [Towards Fully Automatic Placement of Security
Sanitizers and Declassifiers](http://research.microsoft.com/en-us/um/people/livshits/papers/tr/autosani_tr.pdf)
* [Meder Kydyraliev and Josh Deprez: Gravizapa - Ruby and Java Taint Propagation using agent transformations](http://conference.hitb.org/hitbsecconf2012kul/materials/D1T2%20-%20Meder%20Kydyraliev%20-%20Defibrilating%20Web%20Security.pdf)### Other projects
* [Taint propagation in python](https://github.com/felixgr/pytaint/)
## Note
This project is probably not stable for production systems but works quite well in development environment!Everyone is welcome to help to improve this project!
## Quickstart
* Clone the project from github
* ```mvn install``` in the top level directory of the project
* change to the project ```security_taint_webapp```
* ```mvn jetty:run-forked``` starts a webserver
* browse to http://localhost:8080/taintwebapp
* enter some values in the input fields and push the button
* check the console where you started jetty for some warnings about tainted values in jsp page!
* warnings show that some user input (tainted) is output to the web page without sanitation! This
could be used for an XSS hacker attack.## There are multiple parts in this project
* **security_taint_extension**: contains aspects that extend java.lang.String (add property
"tainted"). Therefore you need to weave the new aspect into the jdk's rt.jar (on OSX's
1.6 jdk it is named classes.jar) and create a new "tainted-rt.jar". This new jar is
used in the bootclasspath of all projects that use the aspects (and the application
itself as well!).
* **security_taint_propagation**: holds aspects that propagate the tainted flag from
String to StringBuffer and StringBuilder objects (e.g. copy a tainted String into
a StringBuilder, the new StringBuilder has to be flagged as tainted as well).
Additionally it holds some definitions of sinks and sources.
* **security_taint_propagation_http**: holds taint sources and sinks for web applications
* **security_taint_webapp**: very simple example webapp that demonstrates sources, sinks
and sanitation of tainted strings. It can either be started from a maven jetty with
```mvn jetty:run-forked``` or deployed to an an instrumented tomcat
server (see Readme.md in the project).## Eclipse setup
The projects can be used as maven nature projects. Beware that the tainted-rt-1.x.jar
always comes before the system lib (jre lib) as otherwise the java.lang.String modification
will not be found! Use the projects properties, "Java Build Path"/"Order and Export" to put the
"JRE System Library" to the bottom. This needs to be done every time after "Maven/Update Project"
was executed.Set the default jre to 1.8 (project also works with java 1.6 and java 1.7 - change in parent pom.xml if needed).
Do a ```mvn package``` first, so the modified tainted-rt-1.8.jar will be found in eclipse.
Please note that the security_taint_extension project will not build correctly in eclipse, as
it needs the modified rt.jar which it produces (hen/egg problem). In maven it works.
Use maven to package.Add the aspect-Nature to the project: Right click on project, Configure, Convert to AspectJ Project
If you cannot start any unit tests in eclipse after modification in the aspects, remove all
Run-Configurations of the tests!Sometimes eclipse gets confused and reports hundreds of errors:
* delete the files .classpath and .project
* in eclipse update maven nature: Maven/Update Project
* move the JRE System Library to the bottom (Properties/Java Build Path/Order and Export)
* remove AspectJ Nature and add it again## Working with Taint Propagation
### Tomcat setup
Some libraries are needed to "arm" tomcat:
* the load time weaver of aspectj (as a java agent on startup)
* the aspectj runtime jar (aspectjrt-.jar)
* the modified String class (in tainted-rt.jar) as bootclasspath (replaces the original rt.jar from the jdk)
* the aspect that ensures that the tainted flag is propagated on string operations (security.taint.propagation-.jar) and also contains the sink for sql classes (prevening sql injection attacks).
* the aspect instrumenting http sources and sinks (security.taint.propagation.http-.jar)If you want to start tomcat in eclipse with taint propagation you have to
1. create a new tomcat server named "Tomcat 8 tainted" (or similar)
2. start tomcat once (to get an entry in "Run/Debug configurations")
3. settings in "Run/Debug configurations"
* Arguments:
```
-Xbootclasspath/p:D:/PATH_TO/tainted-rt-1.8.jar
-javaagent:D:/PATH_TO/aspectjweaver-1.8.8.jar
```
* Classpath tab: Add the two jar files in "User Entries": security.taint.propagation-VERSION.jar, security.taint.propagation.http-VERSION.jarIf you want to start a stand-alone tomcat with taint propagation you have to:
first create a setenv.sh/setenv.bat file to add the neccessary jars.
setenv.bat:```
rem setenv.bat: adding taint propagation to tomcat:set BASE_DIR=/security_taint_propagation
set MAVEN_REPO=F:/work/m2repo
set ASPECTJ_VERSION=1.8.8set JAVA_OPTS=-Xbootclasspath/p:%BASE_DIR%/security_taint_extension/target/tainted-rt-1.8.jar %JAVA_OPTS%
set JAVA_OPTS=-javaagent:%MAVEN_REPO%/org/aspectj/aspectjweaver/%ASPECTJ_VERSION%/aspectjweaver-%ASPECTJ_VERSION%.jar %JAVA_OPTS%set JAVA_OPTS=-Xms256m -Xmx1800M -XX:MaxPermSize=256m %JAVA_OPTS%
set JAVA_ENDORSED_DIRS=%MAVEN_REPO%/org/aspectj/aspectjrt/%ASPECTJ_VERSION%/;%JAVA_ENDORSED_DIRS%
set JAVA_ENDORSED_DIRS=%BASE_DIR%/security_taint_propagation_http/target/;%JAVA_ENDORSED_DIRS%
set JAVA_ENDORSED_DIRS=%BASE_DIR%/security_taint_propagation/target/;%JAVA_ENDORSED_DIRS%rem set JAVA_ENDORSED_DIRS=%BASE_DIR%/security_taint_propagation_safehtml/target;%JAVA_ENDORSED_DIRS%
```
setenv.sh is similar :-)then start tomcat as usual
### Output
The tools are configured to print a warning to system.out whenever a security leak was detected (line breaks added for better readability):
```
SECURITY-TAINT-WARNING: Tainted value will be used in a sink![
type: XSS, sink code: org.apache.jsp.xxx.jsp:136/call(JspWriter.print(..)),
tainted sources: JDBC Sql Result Set(5),
value: 'Hugo von Hofmannsthal'
]
```
This means that a tainted string (coming from a insecure source (user input, database)) was detected to be used in a defined sink (jsp writer, database query).## Problems
Some problems make working with taint propagation sometimes cumbersome:
* If a jsp page is the sink (JSP Writer) only the line number in the compiled jsp servlet is printed. So the developer has to find the java code of the jsp page, find the code and then try to find the corresponding line in the jsp file. In eclipse the java classes are placed into $ECLIPSE_WORKSPACE/.metadata/.plugins/org.eclipse.wst.server.core/tmpX/work/Catalina/localhost/$WEBAPPNAME/org/apache/jsp
* The final tainted string is sometimes a concatenation of lots of parts and it is sometimes difficult to find the tainted string.
* It would be helpful to see the different tainted parts of the final string and their way through the code to detect if there really is a security leak or not.
* The project does not work with java 9 or newer because the project modifies the rt.jar file, which was removed in java9 and newer - if someone likes to provide a solution for that, please to not hesitate to contact me.Apart from that the tool works quite reliable.
## License
This project is licensed under [Apache 2.0](http://opensource.org/licenses/apache2.0)