mirror of
https://github.com/guanzhi/GmSSL.git
synced 2026-05-07 08:56:17 +08:00
Merge pull request #869 from xhawk18/master
bug fixed: no fixed order in map may cause GeneratePrivateKey error
This commit is contained in:
@@ -667,11 +667,13 @@ type PrivateKey struct {
|
||||
pkey *C.EVP_PKEY
|
||||
}
|
||||
|
||||
func GeneratePrivateKey(alg string, args map[string]string, eng *Engine) (*PrivateKey, error) {
|
||||
func GeneratePrivateKey(alg string, args [][2]string, eng *Engine) (*PrivateKey, error) {
|
||||
calg := C.CString(alg)
|
||||
defer C.free(unsafe.Pointer(calg))
|
||||
|
||||
ctx := C.new_pkey_keygen_ctx(calg, nil)
|
||||
defer C.EVP_PKEY_CTX_free(ctx)
|
||||
|
||||
/*
|
||||
if eng != nil {
|
||||
ctx := C.new_pkey_keygen_ctx(calg, eng.engine)
|
||||
@@ -688,7 +690,9 @@ func GeneratePrivateKey(alg string, args map[string]string, eng *Engine) (*Priva
|
||||
if 1 != C.EVP_PKEY_paramgen_init(ctx) {
|
||||
return nil, GetErrors()
|
||||
}
|
||||
for name, value := range args {
|
||||
for _, arg := range args {
|
||||
name := arg[0]
|
||||
value := arg[1]
|
||||
cname := C.CString(name)
|
||||
defer C.free(unsafe.Pointer(cname))
|
||||
cvalue := C.CString(value)
|
||||
@@ -712,7 +716,9 @@ func GeneratePrivateKey(alg string, args map[string]string, eng *Engine) (*Priva
|
||||
return nil, GetErrors()
|
||||
}
|
||||
|
||||
for name, value := range args {
|
||||
for _, arg := range args {
|
||||
name := arg[0]
|
||||
value := arg[1]
|
||||
cname := C.CString(name)
|
||||
defer C.free(unsafe.Pointer(cname))
|
||||
cvalue := C.CString(value)
|
||||
@@ -886,6 +892,7 @@ func (pk *PublicKey) Encrypt(alg string, in []byte, eng *Engine) ([]byte, error)
|
||||
if out == nil {
|
||||
return nil, GetErrors()
|
||||
}
|
||||
defer C.free(unsafe.Pointer(out))
|
||||
return C.GoBytes(unsafe.Pointer(out), C.int(outlen)), nil
|
||||
}
|
||||
|
||||
@@ -898,6 +905,7 @@ func (sk *PrivateKey) Decrypt(alg string, in []byte, eng *Engine) ([]byte, error
|
||||
if out == nil {
|
||||
return nil, GetErrors()
|
||||
}
|
||||
defer C.free(unsafe.Pointer(out))
|
||||
return C.GoBytes(unsafe.Pointer(out), C.int(outlen)), nil
|
||||
}
|
||||
|
||||
@@ -911,6 +919,7 @@ func (sk *PrivateKey) Sign(alg string, dgst []byte, eng *Engine) ([]byte, error)
|
||||
C.ERR_print_errors_fp(C.stderr)
|
||||
return nil, GetErrors()
|
||||
}
|
||||
defer C.free(unsafe.Pointer(sig))
|
||||
return C.GoBytes(unsafe.Pointer(sig), C.int(siglen)), nil
|
||||
}
|
||||
|
||||
@@ -934,6 +943,7 @@ func (sk *PrivateKey) DeriveKey(alg string, peer PublicKey, eng *Engine) ([]byte
|
||||
if key == nil {
|
||||
return nil, GetErrors()
|
||||
}
|
||||
defer C.free(unsafe.Pointer(key))
|
||||
return C.GoBytes(unsafe.Pointer(key), C.int(keylen)), nil
|
||||
}
|
||||
|
||||
|
||||
@@ -149,9 +149,9 @@ func main() {
|
||||
fmt.Println()
|
||||
|
||||
/* private key */
|
||||
rsa_args := map[string]string {
|
||||
"rsa_keygen_bits": "2048",
|
||||
"rsa_keygen_pubexp" : "65537",
|
||||
rsa_args := [][2]string{
|
||||
{"rsa_keygen_bits", "2048"},
|
||||
{"rsa_keygen_pubexp", "65537"},
|
||||
}
|
||||
|
||||
rsa, err := gmssl.GeneratePrivateKey("RSA", rsa_args, nil)
|
||||
@@ -175,9 +175,9 @@ func main() {
|
||||
fmt.Println()
|
||||
|
||||
/* SM2 key pair operations */
|
||||
sm2keygenargs := map[string]string {
|
||||
"ec_paramgen_curve": "sm2p256v1",
|
||||
"ec_param_enc": "named_curve",
|
||||
sm2keygenargs := [][2]string{
|
||||
{"ec_paramgen_curve", "sm2p256v1"},
|
||||
{"ec_param_enc", "named_curve"},
|
||||
}
|
||||
sm2sk, _ := gmssl.GeneratePrivateKey("EC", sm2keygenargs, nil)
|
||||
sm2sktxt, _ := sm2sk.GetText()
|
||||
|
||||
Reference in New Issue
Block a user