Documentation
¶
Overview ¶
pemパッケージは、プライバシー拡張メールで起源を持つPEMデータのエンコーディングを実装しています。現在最も一般的なPEMエンコーディングの使用法は、TLSキーと証明書です。RFC 1421を参照してください。
Index ¶
Examples ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func Encode ¶
Encodeは、bのPEMエンコーディングをoutに書き込みます。
Example ¶
package main
import (
"github.com/shogo82148/std/encoding/pem"
"github.com/shogo82148/std/log"
"github.com/shogo82148/std/os"
)
func main() {
block := &pem.Block{
Type: "MESSAGE",
Headers: map[string]string{
"Animal": "Gopher",
},
Bytes: []byte("test"),
}
if err := pem.Encode(os.Stdout, block); err != nil {
log.Fatal(err)
}
}
Output: -----BEGIN MESSAGE----- Animal: Gopher dGVzdA== -----END MESSAGE-----
func EncodeToMemory ¶
EncodeToMemoryはbのPEMエンコーディングを返します。
bが無効なヘッダーを持ちエンコードできない場合、 EncodeToMemoryはnilを返します。このエラーケースの詳細を 報告することが重要な場合は、代わりに Encode を使用してください。
Types ¶
type Block ¶
BlockはPEMエンコードされた構造体を表します。
エンコードされた形式は次のようになります:
-----BEGIN Type----- Headers Base64エンコードされたバイト -----END Type-----
where [Block.Headers] is a possibly empty sequence of Key: Value lines.
func Decode ¶
Decodeは入力から次のPEM形式のブロック(証明書、秘密鍵 など)を見つけます。そのブロックと入力の残りを返します。 PEMデータが見つからない場合、pはnilで、入力全体がrestで返されます。 ブロックは行の始まりから始まり、行の終わりで終わる必要があります。
Example ¶
package main
import (
"github.com/shogo82148/std/crypto/x509"
"github.com/shogo82148/std/encoding/pem"
"github.com/shogo82148/std/fmt"
"github.com/shogo82148/std/log"
)
func main() {
var pubPEMData = []byte(`
-----BEGIN PUBLIC KEY-----
MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAlRuRnThUjU8/prwYxbty
WPT9pURI3lbsKMiB6Fn/VHOKE13p4D8xgOCADpdRagdT6n4etr9atzDKUSvpMtR3
CP5noNc97WiNCggBjVWhs7szEe8ugyqF23XwpHQ6uV1LKH50m92MbOWfCtjU9p/x
qhNpQQ1AZhqNy5Gevap5k8XzRmjSldNAFZMY7Yv3Gi+nyCwGwpVtBUwhuLzgNFK/
yDtw2WcWmUU7NuC8Q6MWvPebxVtCfVp/iQU6q60yyt6aGOBkhAX0LpKAEhKidixY
nP9PNVBvxgu3XZ4P36gZV6+ummKdBVnc3NqwBLu5+CcdRdusmHPHd5pHf4/38Z3/
6qU2a/fPvWzceVTEgZ47QjFMTCTmCwNt29cvi7zZeQzjtwQgn4ipN9NibRH/Ax/q
TbIzHfrJ1xa2RteWSdFjwtxi9C20HUkjXSeI4YlzQMH0fPX6KCE7aVePTOnB69I/
a9/q96DiXZajwlpq3wFctrs1oXqBp5DVrCIj8hU2wNgB7LtQ1mCtsYz//heai0K9
PhE4X6hiE0YmeAZjR0uHl8M/5aW9xCoJ72+12kKpWAa0SFRWLy6FejNYCYpkupVJ
yecLk/4L1W0l6jQQZnWErXZYe0PNFcmwGXy1Rep83kfBRNKRy5tvocalLlwXLdUk
AIU+2GKjyT3iMuzZxxFxPFMCAwEAAQ==
-----END PUBLIC KEY-----
and some more`)
block, rest := pem.Decode(pubPEMData)
if block == nil || block.Type != "PUBLIC KEY" {
log.Fatal("failed to decode PEM block containing public key")
}
pub, err := x509.ParsePKIXPublicKey(block.Bytes)
if err != nil {
log.Fatal(err)
}
fmt.Printf("Got a %T, with remaining data: %q", pub, rest)
}
Output: Got a *rsa.PublicKey, with remaining data: "and some more"
Click to show internal directories.
Click to hide internal directories.