pkcs8格式证书转换pkcs1格式

package main

import (
	"encoding/base64"
	"fmt"
	"os"
	"os/exec"
	"strings"
	"time"

	l_file "github.com/lixu-any/go-tools/file"
)

//pkcs8格式,所以需要转为pkcs1格式,命令=>openssl rsa -in pks8.pem -out pks1.pem
//这里的私钥处理方式 1.以-----BEGIN RSA PRIVATE KEY----- +"换行" +原生字符串64位换行 +"换行" +-----END RSA PRIVATE KEY-----
//2.由于原生秘钥是pkcs8格式,所以需要转为pkcs1格式,命令=>openssl rsa -in pks8.pem -out pks1.pem
//3.openssl 下载地址 https://slproweb.com/products/Win32OpenSSL.html

func WriteToFile(fileName string, content string) error {
	f, err := os.OpenFile(fileName, os.O_WRONLY|os.O_TRUNC|os.O_CREATE, 0644)
	if err != nil {
		fmt.Println("file create failed. err: " + err.Error())
	} else {
		// offset
		//os.Truncate(filename, 0) //clear
		n, _ := f.Seek(0, os.SEEK_END)
		_, err = f.WriteAt([]byte(content), n)
		fmt.Println("write succeed!")
		defer f.Close()
	}
	return err
}

const (
	KEY_BEGIN = "-----BEGIN RSA PRIVATE KEY-----"
	KEY_END   = "-----END RSA PRIVATE KEY-----"
)

func main() {

	var (
		pemstr  string
		nowtime = int32(time.Now().Unix())
		bt      = fmt.Sprintf("1_%d.pem", nowtime)
		wt      = fmt.Sprintf("2_%d.pem", nowtime)
		pt      = fmt.Sprintf("private_%d.txt", nowtime)
	)

	args := os.Args
	if len(args) < 2 {
		fmt.Println("params error")
		return
	}

	pemstr = args[1]
	fomartpem := ""

	parr := strings.Split(pemstr, "")

	for k, v := range parr {
		if k != 0 && k%64 == 0 {
			fomartpem += "\n"
		}
		fomartpem += v
	}

	fomartpem = KEY_BEGIN + "\n" + fomartpem
	fomartpem = fomartpem + "\n" + KEY_END

	os.Create(bt)

	l_file.WriteTxt(bt, fomartpem)

	// command := exec.Command("openssl", "rsa", "-in", "/Users/lixu/code/git/tools/"+bt, "-out", "/Users/lixu/code/git/tools/"+wt, ">mmn.txt")

	cmd := fmt.Sprintf("openssl rsa -in %s -out %s", bt, wt)

	c := exec.Command("bash", "-c", cmd)
	// 此处是windows版本
	// c := exec.Command("cmd", "/C", cmd)
	output, _ := c.CombinedOutput()

	fmt.Println(string(output))

	sbt, _ := l_file.ReadFile(wt)

	signstr := base64.StdEncoding.EncodeToString(sbt)

	fmt.Println(signstr)

	os.Create(pt)

	l_file.WriteTxt(pt, signstr)

}

openssl rsa -in pks8.pem -out pks1.pem

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值