# Enrollment Methods

The core challenge when enrolling certificates is how to authenticate the device or user requesting the certificate.  With the certificate, the CA confirms that the certificate owner has specific properties and that it has checked their authenticity.

Therefore, one core property of certificate enrollment protocols is how they authenticate the certificate requester. Depending on what the certificate is used for, one or the other protocol is more advantageous.

One additional important property is its practical adoption. The enrollment method or protocol must be supported by both the CA and on the client side for the intended use case.

The most popular enrollment protocols are:

* [SCEP](/enrollment-methods/scep.md)
* ACME
* EST
* [Microsoft's RPC/DCOM](/enrollment-methods/microsoft-rpc-dcom.md)
* Microsoft's SOAP
* Manual enrollment on the CA's web page
* Other proprietary protocols

|                | <p>Microsoft proprietary<br>DCOM and RPC</p>          | <p>WS-Trust Enrollment Extension</p><p>SOAP Enrollment</p>                     | <p>Automatic Certificate Management Environment</p><p>(ACME)</p> | Simple Certificate Enrollment Protocol (SCEP) | Enrollment over Secure Transport (EST)  |
| -------------- | ----------------------------------------------------- | ------------------------------------------------------------------------------ | ---------------------------------------------------------------- | --------------------------------------------- | --------------------------------------- |
| Specifications | Microsoft OpenSpec1                                   | Microsoft OpenSpec2                                                            | RFC 8555                                                         | Informal, now RFC 8894                        | RFC 7030 (+ …)                          |
| Implementation | Server side: Active Directory CS Client side: Windows | Server side: ADCS, others?  Client side: Windows                               | Server side: Let’s Encrypt  Client side: Many                    | Many server and client implementations        | Poor adoption                           |
| Authentication | AD Authentication                                     | <p>AD Authentication\*<br>(formally, username/password might not be in AD)</p> | DNS Authentication                                               | “SCEP Challenge”                              | CBA or HTTP Basic/Digest Authentication |


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://www.x509.wiki/enrollment-methods.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
