Step Certificates

用于安全自动证书管理的私有证书颁发机构(X.509 和 SSH)和 ACME 服务器,因此您可以在任何地方使用 TLS,并基于 SSH 使用 SSO。「A private certificate authority (X.509 & SSH) & ACME server for secure automated certificate management, so you can use TLS everywhere & SSO for SSH.」

Github星跟蹤圖

Step Certificates

step-ca is an online certificate authority for secure, automated certificate management. It's the server counterpart to the step CLI tool.

You can use it to:

  • Issue X.509 certificates for your internal infrastructure:
    • HTTPS certificates that work in browsers (RFC5280 and CA/Browser Forum compliance)
    • TLS certificates for VMs, containers, APIs, mobile clients, database connections, printers, wifi networks, toaster ovens...
    • Client certificates to enable mutual TLS (mTLS) in your infra. mTLS is an optional feature in TLS where both client and server authenticate each other. Why add the complexity of a VPN when you can safely use mTLS over the public internet?
  • Issue SSH certificates:
    • For people, in exchange for single sign-on ID tokens
    • For hosts, in exchange for cloud instance identity documents
  • Easily automate certificate management:

Whatever your use case, step-ca is easy to use and hard to misuse, thanks to safe, sane defaults.


Don't want to run your own CA?
To get up and running quickly, or as an alternative to running your own step-ca server, consider creating a free hosted smallstep Certificate Manager authority.


Questions? Find us in Discussions or Join our Discord.

Website |
Documentation |
Installation |
Getting Started |
Contributor's Guide

GitHub release
Go Report Card
Build Status
License
CLA assistant

GitHub stars
Twitter followers

star us

Features

🦾 A fast, stable, flexible private CA

Setting up a public key infrastructure (PKI) is out of reach for many small teams. step-ca makes it easier.

⚙️ Many ways to automate

There are several ways to authorize a request with the CA and establish a chain of trust that suits your flow.

You can issue certificates in exchange for:

🏔 Your own private ACME server

ACME is the protocol used by Let's Encrypt to automate the issuance of HTTPS certificates. It's super easy to issue certificates to any ACMEv2 (RFC8555) client.

👩🏽‍💻 An online SSH Certificate Authority

  • Delegate SSH authentication to step-ca by using SSH certificates instead of public keys and authorized_keys files
  • For user certificates, connect SSH to your single sign-on provider, to improve security with short-lived certificates and MFA (or other security policies) via any OAuth OIDC provider.
  • For host certificates, improve security, eliminate TOFU warnings, and set up automated host certificate renewal.

🤓 A general purpose PKI tool, via step CLI integration

Installation

See our installation docs here.

Documentation

  • Official documentation is on smallstep.com
  • The step command reference is available via step help,
    on smallstep.com,
    or by running step help --http=:8080 from the command line
    and visiting http://localhost:8080.

Feedback?

主要指標

概覽
名稱與所有者smallstep/certificates
主編程語言Go
編程語言Makefile (語言數: 4)
平台Linux, Mac, Windows
許可證Apache License 2.0
所有者活动
創建於2018-11-01 03:44:28
推送於2025-10-22 14:05:49
最后一次提交2025-10-22 14:56:54
發布數233
最新版本名稱v0.28.4 (發布於 )
第一版名稱v0.0.1-rc.1 (發布於 )
用户参与
星數7.8k
關注者數76
派生數504
提交數5.2k
已啟用問題?
問題數665
打開的問題數215
拉請求數1177
打開的拉請求數31
關閉的拉請求數127
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?