Some updates and code improvements (#1288)
* try with resources * StringBuilder * removed ant and updated spring boot
This commit is contained in:
		
							
								
								
									
										21
									
								
								pom.xml
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								pom.xml
									
									
									
									
									
								
							| @ -11,7 +11,7 @@ | |||||||
|     <parent> |     <parent> | ||||||
|         <groupId>org.springframework.boot</groupId> |         <groupId>org.springframework.boot</groupId> | ||||||
|         <artifactId>spring-boot-starter-parent</artifactId> |         <artifactId>spring-boot-starter-parent</artifactId> | ||||||
|         <version>2.6.6</version> |         <version>2.7.1</version> | ||||||
|     </parent> |     </parent> | ||||||
|  |  | ||||||
|     <name>WebGoat</name> |     <name>WebGoat</name> | ||||||
| @ -119,7 +119,6 @@ | |||||||
|         <webwolf.port>9090</webwolf.port> |         <webwolf.port>9090</webwolf.port> | ||||||
|  |  | ||||||
|         <!-- Shared properties with plugins and version numbers across submodules--> |         <!-- Shared properties with plugins and version numbers across submodules--> | ||||||
|         <ant.version>1.6.5</ant.version> |  | ||||||
|         <asciidoctorj.version>2.5.2</asciidoctorj.version> |         <asciidoctorj.version>2.5.2</asciidoctorj.version> | ||||||
|         <bootstrap.version>3.3.7</bootstrap.version> |         <bootstrap.version>3.3.7</bootstrap.version> | ||||||
|         <cglib.version>2.2</cglib.version> <!-- do not update necessary for lesson --> |         <cglib.version>2.2</cglib.version> <!-- do not update necessary for lesson --> | ||||||
| @ -181,16 +180,6 @@ | |||||||
|                 <artifactId>cglib-nodep</artifactId> |                 <artifactId>cglib-nodep</artifactId> | ||||||
|                 <version>${cglib.version}</version> |                 <version>${cglib.version}</version> | ||||||
|             </dependency> |             </dependency> | ||||||
|             <dependency> |  | ||||||
|                 <groupId>ant</groupId> |  | ||||||
|                 <artifactId>ant-launcher</artifactId> |  | ||||||
|                 <version>${ant.version}</version> |  | ||||||
|             </dependency> |  | ||||||
|             <dependency> |  | ||||||
|                 <groupId>ant</groupId> |  | ||||||
|                 <artifactId>ant</artifactId> |  | ||||||
|                 <version>${ant.version}</version> |  | ||||||
|             </dependency> |  | ||||||
|             <dependency> |             <dependency> | ||||||
|                 <groupId>xml-resolver</groupId> |                 <groupId>xml-resolver</groupId> | ||||||
|                 <artifactId>xml-resolver</artifactId> |                 <artifactId>xml-resolver</artifactId> | ||||||
| @ -452,14 +441,6 @@ | |||||||
|             <groupId>cglib</groupId> |             <groupId>cglib</groupId> | ||||||
|             <artifactId>cglib-nodep</artifactId> |             <artifactId>cglib-nodep</artifactId> | ||||||
|         </dependency> |         </dependency> | ||||||
|         <dependency> |  | ||||||
|             <groupId>ant</groupId> |  | ||||||
|             <artifactId>ant-launcher</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|         <dependency> |  | ||||||
|             <groupId>ant</groupId> |  | ||||||
|             <artifactId>ant</artifactId> |  | ||||||
|         </dependency> |  | ||||||
|         <dependency> |         <dependency> | ||||||
|             <groupId>xml-resolver</groupId> |             <groupId>xml-resolver</groupId> | ||||||
|             <artifactId>xml-resolver</artifactId> |             <artifactId>xml-resolver</artifactId> | ||||||
|  | |||||||
| @ -164,9 +164,10 @@ public class MD5 { | |||||||
|      * @since ostermillerutils 1.00.00 |      * @since ostermillerutils 1.00.00 | ||||||
|      */ |      */ | ||||||
|     public static byte[] getHash(File f) throws IOException { |     public static byte[] getHash(File f) throws IOException { | ||||||
|         InputStream is = new FileInputStream(f); |         byte[] hash = null; | ||||||
|         byte[] hash = getHash(is); |         try (InputStream is = new FileInputStream(f)) { | ||||||
|         is.close(); |             hash = getHash(is); | ||||||
|  |         } | ||||||
|         return hash; |         return hash; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @ -179,9 +180,10 @@ public class MD5 { | |||||||
|      * @since ostermillerutils 1.00.00 |      * @since ostermillerutils 1.00.00 | ||||||
|      */ |      */ | ||||||
|     public static String getHashString(File f) throws IOException { |     public static String getHashString(File f) throws IOException { | ||||||
|         InputStream is = new FileInputStream(f); |         String hash = null; | ||||||
|         String hash = getHashString(is); |         try (InputStream is = new FileInputStream(f)) { | ||||||
|         is.close(); |             hash = getHashString(is); | ||||||
|  |         } | ||||||
|         return hash; |         return hash; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @ -515,7 +517,7 @@ public class MD5 { | |||||||
|      * @since ostermillerutils 1.00.00 |      * @since ostermillerutils 1.00.00 | ||||||
|      */ |      */ | ||||||
|     private static String toHex(byte hash[]) { |     private static String toHex(byte hash[]) { | ||||||
|         StringBuffer buf = new StringBuffer(hash.length * 2); |         StringBuilder buf = new StringBuilder(hash.length * 2); | ||||||
|         for (byte element : hash) { |         for (byte element : hash) { | ||||||
|             int intVal = element & 0xff; |             int intVal = element & 0xff; | ||||||
|             if (intVal < 0x10) { |             if (intVal < 0x10) { | ||||||
|  | |||||||
| @ -76,10 +76,14 @@ public class Salaries { | |||||||
|         File d = new File(webGoatHomeDirectory, "ClientSideFiltering/employees.xml"); |         File d = new File(webGoatHomeDirectory, "ClientSideFiltering/employees.xml"); | ||||||
|         XPathFactory factory = XPathFactory.newInstance(); |         XPathFactory factory = XPathFactory.newInstance(); | ||||||
|         XPath path = factory.newXPath(); |         XPath path = factory.newXPath(); | ||||||
|  |         int columns = 5; | ||||||
|  |         List<Map<String, Object>> json = new ArrayList<>(); | ||||||
|  |         java.util.Map<String, Object> employeeJson = new HashMap<>(); | ||||||
|  |  | ||||||
|         try (InputStream is = new FileInputStream(d)) { |         try (InputStream is = new FileInputStream(d)) { | ||||||
|             InputSource inputSource = new InputSource(is); |             InputSource inputSource = new InputSource(is); | ||||||
|  |  | ||||||
|             StringBuffer sb = new StringBuffer(); |             StringBuilder sb = new StringBuilder(); | ||||||
|  |  | ||||||
|             sb.append("/Employees/Employee/UserID | "); |             sb.append("/Employees/Employee/UserID | "); | ||||||
|             sb.append("/Employees/Employee/FirstName | "); |             sb.append("/Employees/Employee/FirstName | "); | ||||||
| @ -89,22 +93,19 @@ public class Salaries { | |||||||
|  |  | ||||||
|             String expression = sb.toString(); |             String expression = sb.toString(); | ||||||
|             nodes = (NodeList) path.evaluate(expression, inputSource, XPathConstants.NODESET); |             nodes = (NodeList) path.evaluate(expression, inputSource, XPathConstants.NODESET); | ||||||
|  |             for (int i = 0; i < nodes.getLength(); i++) { | ||||||
|  |                 if (i % columns == 0) { | ||||||
|  |                     employeeJson = new HashMap<>(); | ||||||
|  |                     json.add(employeeJson); | ||||||
|  |                 } | ||||||
|  |                 Node node = nodes.item(i); | ||||||
|  |                 employeeJson.put(node.getNodeName(), node.getTextContent()); | ||||||
|  |             } | ||||||
|         } catch (XPathExpressionException e) { |         } catch (XPathExpressionException e) { | ||||||
|             log.error("Unable to parse xml", e); |             log.error("Unable to parse xml", e); | ||||||
|         } catch (IOException e) { |         } catch (IOException e) { | ||||||
|             log.error("Unable to read employees.xml at location: '{}'", d); |             log.error("Unable to read employees.xml at location: '{}'", d); | ||||||
|         } |         } | ||||||
|         int columns = 5; |  | ||||||
|         List json = new ArrayList(); |  | ||||||
|         java.util.Map<String, Object> employeeJson = new HashMap<>(); |  | ||||||
|         for (int i = 0; i < nodes.getLength(); i++) { |  | ||||||
|             if (i % columns == 0) { |  | ||||||
|                 employeeJson = new HashMap<>(); |  | ||||||
|                 json.add(employeeJson); |  | ||||||
|             } |  | ||||||
|             Node node = nodes.item(i); |  | ||||||
|             employeeJson.put(node.getNodeName(), node.getTextContent()); |  | ||||||
|         } |  | ||||||
|         return json; |         return json; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -42,7 +42,7 @@ public class SecurePasswordsAssignment extends AssignmentEndpoint { | |||||||
|     @ResponseBody |     @ResponseBody | ||||||
|     public AttackResult completed(@RequestParam String password) { |     public AttackResult completed(@RequestParam String password) { | ||||||
|         Zxcvbn zxcvbn = new Zxcvbn(); |         Zxcvbn zxcvbn = new Zxcvbn(); | ||||||
|         StringBuffer output = new StringBuffer(); |         StringBuilder output = new StringBuilder(); | ||||||
|         DecimalFormat df = new DecimalFormat("0", DecimalFormatSymbols.getInstance(Locale.ENGLISH)); |         DecimalFormat df = new DecimalFormat("0", DecimalFormatSymbols.getInstance(Locale.ENGLISH)); | ||||||
|         df.setMaximumFractionDigits(340); |         df.setMaximumFractionDigits(340); | ||||||
|         Strength strength = zxcvbn.measure(password); |         Strength strength = zxcvbn.measure(password); | ||||||
|  | |||||||
| @ -68,7 +68,7 @@ public class SqlInjectionLesson6a extends AssignmentEndpoint { | |||||||
|  |  | ||||||
|                 if ((results != null) && (results.first())) { |                 if ((results != null) && (results.first())) { | ||||||
|                     ResultSetMetaData resultsMetaData = results.getMetaData(); |                     ResultSetMetaData resultsMetaData = results.getMetaData(); | ||||||
|                     StringBuffer output = new StringBuffer(); |                     StringBuilder output = new StringBuilder(); | ||||||
|  |  | ||||||
|                     output.append(SqlInjectionLesson5a.writeTable(results, resultsMetaData)); |                     output.append(SqlInjectionLesson5a.writeTable(results, resultsMetaData)); | ||||||
|  |  | ||||||
|  | |||||||
| @ -54,7 +54,7 @@ public class SqlInjectionLesson10 extends AssignmentEndpoint { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     protected AttackResult injectableQueryAvailability(String action) { |     protected AttackResult injectableQueryAvailability(String action) { | ||||||
|         StringBuffer output = new StringBuffer(); |         StringBuilder output = new StringBuilder(); | ||||||
|         String query = "SELECT * FROM access_log WHERE action LIKE '%" + action + "%'"; |         String query = "SELECT * FROM access_log WHERE action LIKE '%" + action + "%'"; | ||||||
|  |  | ||||||
|         try (Connection connection = dataSource.getConnection()) { |         try (Connection connection = dataSource.getConnection()) { | ||||||
|  | |||||||
| @ -60,7 +60,7 @@ public class SqlInjectionLesson2 extends AssignmentEndpoint { | |||||||
|         try (var connection = dataSource.getConnection()) { |         try (var connection = dataSource.getConnection()) { | ||||||
|             Statement statement = connection.createStatement(TYPE_SCROLL_INSENSITIVE, CONCUR_READ_ONLY); |             Statement statement = connection.createStatement(TYPE_SCROLL_INSENSITIVE, CONCUR_READ_ONLY); | ||||||
|             ResultSet results = statement.executeQuery(query); |             ResultSet results = statement.executeQuery(query); | ||||||
|             StringBuffer output = new StringBuffer(); |             StringBuilder output = new StringBuilder(); | ||||||
|  |  | ||||||
|             results.first(); |             results.first(); | ||||||
|  |  | ||||||
|  | |||||||
| @ -64,7 +64,7 @@ public class SqlInjectionLesson3 extends AssignmentEndpoint { | |||||||
|                         CONCUR_READ_ONLY); |                         CONCUR_READ_ONLY); | ||||||
|                 statement.executeUpdate(query); |                 statement.executeUpdate(query); | ||||||
|                 ResultSet results = checkStatement.executeQuery("SELECT * FROM employees WHERE last_name='Barnett';"); |                 ResultSet results = checkStatement.executeQuery("SELECT * FROM employees WHERE last_name='Barnett';"); | ||||||
|                 StringBuffer output = new StringBuffer(); |                 StringBuilder output = new StringBuilder(); | ||||||
|                 // user completes lesson if the department of Tobi Barnett now is 'Sales' |                 // user completes lesson if the department of Tobi Barnett now is 'Sales' | ||||||
|                 results.first(); |                 results.first(); | ||||||
|                 if (results.getString("department").equals("Sales")) { |                 if (results.getString("department").equals("Sales")) { | ||||||
|  | |||||||
| @ -63,7 +63,7 @@ public class SqlInjectionLesson4 extends AssignmentEndpoint { | |||||||
|                 statement.executeUpdate(query); |                 statement.executeUpdate(query); | ||||||
|                 connection.commit(); |                 connection.commit(); | ||||||
|                 ResultSet results = statement.executeQuery("SELECT phone from employees;"); |                 ResultSet results = statement.executeQuery("SELECT phone from employees;"); | ||||||
|                 StringBuffer output = new StringBuffer(); |                 StringBuilder output = new StringBuilder(); | ||||||
|                 // user completes lesson if column phone exists |                 // user completes lesson if column phone exists | ||||||
|                 if (results.first()) { |                 if (results.first()) { | ||||||
|                     output.append("<span class='feedback-positive'>" + query + "</span>"); |                     output.append("<span class='feedback-positive'>" + query + "</span>"); | ||||||
|  | |||||||
| @ -72,7 +72,7 @@ public class SqlInjectionLesson5b extends AssignmentEndpoint { | |||||||
|  |  | ||||||
|                 if ((results != null) && (results.first() == true)) { |                 if ((results != null) && (results.first() == true)) { | ||||||
|                     ResultSetMetaData resultsMetaData = results.getMetaData(); |                     ResultSetMetaData resultsMetaData = results.getMetaData(); | ||||||
|                     StringBuffer output = new StringBuffer(); |                     StringBuilder output = new StringBuilder(); | ||||||
|  |  | ||||||
|                     output.append(SqlInjectionLesson5a.writeTable(results, resultsMetaData)); |                     output.append(SqlInjectionLesson5a.writeTable(results, resultsMetaData)); | ||||||
|                     results.last(); |                     results.last(); | ||||||
|  | |||||||
| @ -56,7 +56,7 @@ public class SqlInjectionLesson8 extends AssignmentEndpoint { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     protected AttackResult injectableQueryConfidentiality(String name, String auth_tan) { |     protected AttackResult injectableQueryConfidentiality(String name, String auth_tan) { | ||||||
|         StringBuffer output = new StringBuffer(); |         StringBuilder output = new StringBuilder(); | ||||||
|         String query = "SELECT * FROM employees WHERE last_name = '" + name + "' AND auth_tan = '" + auth_tan + "'"; |         String query = "SELECT * FROM employees WHERE last_name = '" + name + "' AND auth_tan = '" + auth_tan + "'"; | ||||||
|  |  | ||||||
|         try (Connection connection = dataSource.getConnection()) { |         try (Connection connection = dataSource.getConnection()) { | ||||||
| @ -98,7 +98,7 @@ public class SqlInjectionLesson8 extends AssignmentEndpoint { | |||||||
|         ResultSetMetaData resultsMetaData = results.getMetaData(); |         ResultSetMetaData resultsMetaData = results.getMetaData(); | ||||||
|         int numColumns = resultsMetaData.getColumnCount(); |         int numColumns = resultsMetaData.getColumnCount(); | ||||||
|         results.beforeFirst(); |         results.beforeFirst(); | ||||||
|         StringBuffer table = new StringBuffer(); |         StringBuilder table = new StringBuilder(); | ||||||
|         table.append("<table>"); |         table.append("<table>"); | ||||||
|  |  | ||||||
|         if (results.next()) { |         if (results.next()) { | ||||||
|  | |||||||
| @ -57,7 +57,7 @@ public class SqlInjectionLesson9 extends AssignmentEndpoint { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     protected AttackResult injectableQueryIntegrity(String name, String auth_tan) { |     protected AttackResult injectableQueryIntegrity(String name, String auth_tan) { | ||||||
|         StringBuffer output = new StringBuffer(); |         StringBuilder output = new StringBuilder(); | ||||||
|         String query = "SELECT * FROM employees WHERE last_name = '" + name + "' AND auth_tan = '" + auth_tan + "'"; |         String query = "SELECT * FROM employees WHERE last_name = '" + name + "' AND auth_tan = '" + auth_tan + "'"; | ||||||
|         try (Connection connection = dataSource.getConnection()) { |         try (Connection connection = dataSource.getConnection()) { | ||||||
|             try { |             try { | ||||||
| @ -86,7 +86,7 @@ public class SqlInjectionLesson9 extends AssignmentEndpoint { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private AttackResult checkSalaryRanking(Connection connection, StringBuffer output) { |     private AttackResult checkSalaryRanking(Connection connection, StringBuilder output) { | ||||||
|         try { |         try { | ||||||
|             String query = "SELECT * FROM employees ORDER BY salary DESC"; |             String query = "SELECT * FROM employees ORDER BY salary DESC"; | ||||||
|             try (Statement statement = connection.createStatement(TYPE_SCROLL_SENSITIVE, CONCUR_UPDATABLE); |             try (Statement statement = connection.createStatement(TYPE_SCROLL_SENSITIVE, CONCUR_UPDATABLE); | ||||||
|  | |||||||
| @ -43,7 +43,7 @@ public class SSRFTask1 extends AssignmentEndpoint { | |||||||
|  |  | ||||||
|     protected AttackResult stealTheCheese(String url) { |     protected AttackResult stealTheCheese(String url) { | ||||||
|         try { |         try { | ||||||
|             StringBuffer html = new StringBuffer(); |             StringBuilder html = new StringBuilder(); | ||||||
|  |  | ||||||
|             if (url.matches("images/tom.png")) { |             if (url.matches("images/tom.png")) { | ||||||
|                 html.append("<img class=\"image\" alt=\"Tom\" src=\"images/tom.png\" width=\"25%\" height=\"25%\">"); |                 html.append("<img class=\"image\" alt=\"Tom\" src=\"images/tom.png\" width=\"25%\" height=\"25%\">"); | ||||||
|  | |||||||
| @ -61,7 +61,7 @@ public class CrossSiteScriptingLesson5a extends AssignmentEndpoint { | |||||||
|         double totalSale = QTY1.intValue() * 69.99 + QTY2.intValue() * 27.99 + QTY3.intValue() * 1599.99 + QTY4.intValue() * 299.99; |         double totalSale = QTY1.intValue() * 69.99 + QTY2.intValue() * 27.99 + QTY3.intValue() * 1599.99 + QTY4.intValue() * 299.99; | ||||||
|  |  | ||||||
|         userSessionData.setValue("xss-reflected1-complete", "false"); |         userSessionData.setValue("xss-reflected1-complete", "false"); | ||||||
|         StringBuffer cart = new StringBuffer(); |         StringBuilder cart = new StringBuilder(); | ||||||
|         cart.append("Thank you for shopping at WebGoat. <br />Your support is appreciated<hr />"); |         cart.append("Thank you for shopping at WebGoat. <br />Your support is appreciated<hr />"); | ||||||
|         cart.append("<p>We have charged credit card:" + field1 + "<br />"); |         cart.append("<p>We have charged credit card:" + field1 + "<br />"); | ||||||
|         cart.append("                             ------------------- <br />"); |         cart.append("                             ------------------- <br />"); | ||||||
|  | |||||||
| @ -51,7 +51,7 @@ even if it is hidden it is easy to find the sensitive date. In this | |||||||
| stage you will add a filter to the XPath queries. In this file you will find  | stage you will add a filter to the XPath queries. In this file you will find  | ||||||
| following construct:<br><br></p> | following construct:<br><br></p> | ||||||
| <code> | <code> | ||||||
| 	StringBuffer sb = new StringBuffer();<br> | 	StringBuilder sb = new StringBuilder();<br> | ||||||
| 	 | 	 | ||||||
| 	sb.append("/Employees/Employee/UserID | ");<br> | 	sb.append("/Employees/Employee/UserID | ");<br> | ||||||
| 	sb.append("/Employees/Employee/FirstName | ");<br> | 	sb.append("/Employees/Employee/FirstName | ");<br> | ||||||
| @ -66,7 +66,7 @@ This string will be used for the XPath query. You have to guarantee that a mange | |||||||
| can see employees which are working for him. To archive this you can use | can see employees which are working for him. To archive this you can use | ||||||
| filters in XPath. Following code will exactly do this:</p> | filters in XPath. Following code will exactly do this:</p> | ||||||
| <code> | <code> | ||||||
| 	StringBuffer sb = new StringBuffer();<br> | 	StringBuilder sb = new StringBuilder();<br> | ||||||
| 	 | 	 | ||||||
| 	sb.append("/Employees/Employee[Managers/Manager/text() = " + userId + "]/UserID | ");<br> | 	sb.append("/Employees/Employee[Managers/Manager/text() = " + userId + "]/UserID | ");<br> | ||||||
| 	sb.append("/Employees/Employee[Managers/Manager/text() = " + userId + "]/FirstName | ");<br> | 	sb.append("/Employees/Employee[Managers/Manager/text() = " + userId + "]/FirstName | ");<br> | ||||||
| @ -81,4 +81,4 @@ Now only information is sent to your client you are authorized for. You can clic | |||||||
| </p> | </p> | ||||||
|  |  | ||||||
| </body> | </body> | ||||||
| </html> | </html> | ||||||
|  | |||||||
| @ -831,7 +831,7 @@ var JavaHighlightRules = function() { | |||||||
|         "Readable|Runtime|StringBuilder|Math|IncompatibleClassChangeError|"+ |         "Readable|Runtime|StringBuilder|Math|IncompatibleClassChangeError|"+ | ||||||
|         "NoSuchMethodError|ThreadLocal|RuntimePermission|ArithmeticException|"+ |         "NoSuchMethodError|ThreadLocal|RuntimePermission|ArithmeticException|"+ | ||||||
|         "NullPointerException|Long|Integer|Short|Byte|Double|Number|Float|"+ |         "NullPointerException|Long|Integer|Short|Byte|Double|Number|Float|"+ | ||||||
|         "Character|Boolean|StackTraceElement|Appendable|StringBuffer|"+ |         "Character|Boolean|StackTraceElement|Appendable|StringBuilder|"+ | ||||||
|         "Iterable|ThreadGroup|Runnable|Thread|IllegalMonitorStateException|"+ |         "Iterable|ThreadGroup|Runnable|Thread|IllegalMonitorStateException|"+ | ||||||
|         "StackOverflowError|OutOfMemoryError|VirtualMachineError|"+ |         "StackOverflowError|OutOfMemoryError|VirtualMachineError|"+ | ||||||
|         "ArrayStoreException|ClassCastException|LinkageError|"+ |         "ArrayStoreException|ClassCastException|LinkageError|"+ | ||||||
|  | |||||||
| @ -311,14 +311,14 @@ define(['module'], function (module) { | |||||||
|             typeof Packages !== 'undefined' && typeof java !== 'undefined')) { |             typeof Packages !== 'undefined' && typeof java !== 'undefined')) { | ||||||
|         //Why Java, why is this so awkward? |         //Why Java, why is this so awkward? | ||||||
|         text.get = function (url, callback) { |         text.get = function (url, callback) { | ||||||
|             var stringBuffer, line, |             var stringBuilder, line, | ||||||
|                 encoding = "utf-8", |                 encoding = "utf-8", | ||||||
|                 file = new java.io.File(url), |                 file = new java.io.File(url), | ||||||
|                 lineSeparator = java.lang.System.getProperty("line.separator"), |                 lineSeparator = java.lang.System.getProperty("line.separator"), | ||||||
|                 input = new java.io.BufferedReader(new java.io.InputStreamReader(new java.io.FileInputStream(file), encoding)), |                 input = new java.io.BufferedReader(new java.io.InputStreamReader(new java.io.FileInputStream(file), encoding)), | ||||||
|                 content = ''; |                 content = ''; | ||||||
|             try { |             try { | ||||||
|                 stringBuffer = new java.lang.StringBuffer(); |                 stringBuilder = new java.lang.StringBuilder(); | ||||||
|                 line = input.readLine(); |                 line = input.readLine(); | ||||||
|  |  | ||||||
|                 // Byte Order Mark (BOM) - The Unicode Standard, version 3.0, page 324 |                 // Byte Order Mark (BOM) - The Unicode Standard, version 3.0, page 324 | ||||||
| @ -334,15 +334,15 @@ define(['module'], function (module) { | |||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 if (line !== null) { |                 if (line !== null) { | ||||||
|                     stringBuffer.append(line); |                     stringBuilder.append(line); | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 while ((line = input.readLine()) !== null) { |                 while ((line = input.readLine()) !== null) { | ||||||
|                     stringBuffer.append(lineSeparator); |                     stringBuilder.append(lineSeparator); | ||||||
|                     stringBuffer.append(line); |                     stringBuilder.append(line); | ||||||
|                 } |                 } | ||||||
|                 //Make sure we return a JavaScript string and not a Java string. |                 //Make sure we return a JavaScript string and not a Java string. | ||||||
|                 content = String(stringBuffer.toString()); //String |                 content = String(stringBuilder.toString()); //String | ||||||
|             } finally { |             } finally { | ||||||
|                 input.close(); |                 input.close(); | ||||||
|             } |             } | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user