Skip to main content

CWE-577: EJB Bad Practices: Use of Sockets

VariantDraft

The product violates the Enterprise JavaBeans (EJB) specification by using sockets.

View on MITRE
Back to CWE Lookup

Extended Description

The Enterprise JavaBeans specification requires that every bean provider follow a set of programming guidelines designed to ensure that the bean will be portable and behave consistently in any EJB container. In this case, the product violates the following EJB guideline: "An enterprise bean must not attempt to listen on a socket, accept connections on a socket, or use a socket for multicast." The specification justifies this requirement in the following way: "The EJB architecture allows an enterprise bean instance to be a network socket client, but it does not allow it to be a network server. Allowing the instance to become a network server would conflict with the basic function of the enterprise bean-- to serve the EJB clients."

Technical Details

Structure
Simple

Applicable To

Languages
Java
Platforms

Frequently Asked Questions

What is CWE-577: EJB Bad Practices: Use of Sockets?+

CWE-577: EJB Bad Practices: Use of Sockets is a Common Weakness Enumeration (CWE) entry maintained by MITRE. The product violates the Enterprise JavaBeans (EJB) specification by using sockets. The Enterprise JavaBeans specification requires that every bean provider follow a set of programming guidelines designed to ensure that the bean will be portable and behave consistently in any EJB container. In this case, the product violates the following EJB guideline: "An enterprise bean must not attempt to listen on a socket, accept connections on a socket, or use a socket for multicast." The specification justifies this requirement in the following way: "The EJB architecture allows an enterprise bean instance to be a network socket client, but it does not allow it to be a network server. Allowing the instance to become a network server would conflict with the basic function of the enterprise bean-- to serve the EJB clients."

What are the security consequences of EJB Bad Practices: Use of Sockets?+

If exploited, CWE-577 (EJB Bad Practices: Use of Sockets) it can compromise Other, leading to outcomes such as Quality Degradation.

How do you prevent or mitigate EJB Bad Practices: Use of Sockets?+

Recommended mitigations for CWE-577 include: Do not use Sockets when writing EJBs.

Which programming languages are affected by EJB Bad Practices: Use of Sockets?+

CWE-577 commonly affects Java. Note that weaknesses are often language-agnostic patterns, so secure coding practices apply broadly.

What is the difference between a CWE and a CVE?+

A CWE (Common Weakness Enumeration) like CWE-577 describes a category of software weakness — the underlying flaw type. A CVE (Common Vulnerabilities and Exposures) identifies a specific, real-world vulnerability in a particular product. In short, a CWE is the kind of mistake, and a CVE is an instance of that mistake being found in software.

Learn More