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エンコーディングを返します。
If b has invalid headers and cannot be encoded, EncodeToMemory returns nil. If it is important to report details about this error case, use Encode instead.
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.