Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Comment: Corrected "Create a sign-in account" link

Include Page
seccode:Secure Coding Space Homepage Notices
seccode:Secure Coding Space Homepage Notices


The Java rules and recommendations in this wiki are a work in progress and reflect the current thinking of the secure coding community. Because this is a development website, many pages are incomplete or contain errors. As rules and recommendations mature, they are published in report or book form as official releases. These releases are issued as dictated by the needs and interests of the secure software development community.

Create a sign-in account if you want to comment on existing content. If you wish to be more involved and directly edit content on the site, you still need an account, but you'll also need to request edit privileges.   


Front Matter

Content by Label
showLabelsfalse
max99
spaces@self
showSpacefalse
sorttitle
reversetrue
cqllabel = "rule" and label = "front-matter" and space = currentSpace()
labels+rule, +intro

Rules

Content by Label
showLabelsfalse
max99
spaces@self
showSpacefalse
sorttitle
cqllabel = "rule-list" and label != "void" and space = currentSpace()
labels+rule-list -void


Content by Label
showLabelsfalse
max99
spaces@self
showSpacefalse
sorttitle
cqllabel = "rule" and label = "bm" and space = currentSpace()
labels+rule, +bm

Front Matter 

Content by Label
showLabelsfalse
max99
spaces@self
showSpacefalse
sorttitle
reversetrue
cqllabel = "recommendation" and label = "front-matter" and space = currentSpace()
labels+recommendation, +intro

Recommendations

Content by Label
showLabelsfalse
max99
spaces@self
showSpacefalse
sorttitle
cqllabel = "recommendation-list" and space = currentSpace()
labels+recommendation-list


Content by Label
showLabelsfalse
max99
spaces@self
showSpacefalse
sorttitle
cqllabel = "recommendation" and label = "bm" and space = currentSpace()
labels+recommendation, +bm

Panel
borderColor#B0B1BA
bgColor#fafafa
titleColor#ffffff
borderWidth1
titleBGColor#B0B1BA
borderStylesolid
titleSecure Java Coding Books

There are two books available that cover Java: one for rules and the other for guidelines.

Image AddedThe CERT Oracle Secure Coding Standard for Java provides rules for Java Platform Standard Edition 6 and Java SE 7.

 


Image AddedJava Coding Guidelines: 75 Recommendations for Reliable and Secure Programs provides guidelines, recommendations, and examples to enable the creation of reliable, robust, fast, maintainable, and secure code.
Panel
borderColor#B0B1BA
bgColor#fafafa
titleColor#ffffff
borderWidth1
titleBGColor#B0B1BA
borderStylesolid
titleSource Code Analysis Laboratory (SCALe)

SCALe offers conformance testing of Java language software systems against the CERT Oracle Secure Coding Standard for Java.

Panel
borderColor#B0B1BA
bgColor#fafafa
titleColor#ffffff
borderWidth1
titleBGColor#B0B1BA
borderStylesolid
titleContact Us

Contact us if you

  • have questions about the Secure Coding wiki
  • have recommendations for standards in development
  • want to request privileges to participate in standards development
Panel
borderColor#B0B1BA
bgColor#fafafa
titleColor#ffffff
borderWidth1
titleBGColor#B0B1BA
borderStylesolid
titleThank You!

We acknowledge the contributions of the following folks , and we look forward to seeing your name here as well.

Include Page
seccode:Understand the Difference Between Rules and Recommendations
seccode:Understand the Difference Between Rules and Recommendations

Info
titleLinking to Our Pages

Link to guidelines using the Tiny Link under Tools→Link to this Page... (This URL will not change if the name of the guideline changes.)   

Info
titleInformation for Editors
  • To eliminate a section from the lists above, label it section and void.
  • To have a section listed as a recommendation, label it section and recommendation.
  • To have a section listed as a rule, label it section and rule

The CERT Sun Microsystems Secure Coding Standard for Java includes rules and recommended practices for secure programming in the Java Platform Standard Edition 6 environment including the CORE API and perhaps the Non-Core APIs included in JDK 1.6.

00. Introduction

01. Runtime Environment (ENV)

02. Platform Security (SEC)

03. Declarations and Initialization (DCL)

04. Expressions (EXP)

05. Scope (SCP)

06. Integers (INT)

07. Floating Point (FLP)

08. Object Orientation (OBJ)

09. Input Output (FIO)

10. Input Sanitization and Data Validation (SDV)

11. Concurrency (CON)

11. Methods (MET)

12. Exceptional Behavior (EXC)

13. Serialization (SER)

49. Miscellaneous (MSC)

99. The Void (VOID)

AA. Java References

AZ. General Comments

...

  • .