Как читать содержимое pkcs12 в golang, у меня есть пример на PHP

Есть интерфейс расшифровки и подписи. Я хочу перейти с PHP на Golang. Функция PHP выглядит следующим образом:

function getSignature($param){
if (is_string($param)) {
    $file_private = 'file.p12';
    if (!$cert_store = file_get_contents($file_private)) {
        return "Error: Unable to read the cert file\n";
    }
    $signature = "";
    $algo = "sha256WithRSAEncryption";
    $password = "PASSWORD";
    $private_key_file = openssl_pkcs12_read($cert_store, $cert_info, $password);
    if ($private_key_file)
    {
        $private_key = $cert_info['pkey'];
        openssl_sign($param, $signature, $private_key, $algo);
        return htmlentities(base64_encode($signature));
    }

}
return false;
}

Я хочу использовать голанг для достижения цели. Как я могу конвертировать в голанг?

Решено

Вот что на самом деле мой код в golang:

func Sign(privateKey *rsa.PrivateKey, data string) (string, error) {
h := crypto.SHA256.New()
h.Write([]byte(data))
hashed := h.Sum(nil)

sign, err := rsa.SignPKCS1v15(rand.Reader, privateKey, crypto.SHA256, hashed)
if err != nil {
    return "", err
}
return base64.RawURLEncoding.EncodeToString(sign), err
}


func read_keys() {
b, err := ioutil.ReadFile("file.p12")
if err != nil {
    fmt.Println(err)

}
password := "PASSWORD"
privk, _, err := pkcs12.Decode(b, password)
if err != nil {
    fmt.Println(err)
}
pv := privk.(*rsa.PrivateKey)
sign, _ := Sign(pv, "Your String Data")
fmt.Print(sign)
}

Что вы пробовали до сих пор и где это не удалось? StackOverflow не является сервисом кодирования.

nijm 12.10.2018 11:19

Этот пример с использованием php, в моей системе, написанной на golang, я хочу преобразовать такие функции, как openssl_pkcs12_read и openssl_sign, в golang @nijm

andrey_derma 12.10.2018 11:21
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
3
2
1 629
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

это - это пакет, который вы ищете

data, err := ioutil.ReadFile(*in)

if err != nil {
    log.Fatal(err)
}

privateKey, certificate, err := pkcs12.Decode(data, *password)
if err != nil {
    log.Fatal(err)
}

pv := privateKey.(*rsa.PrivateKey)
signature, err := rsa.SignPKCS1v15(rand.Reader, privateKey, rypto.SHA256, hash)
if err != nil {
    log.Fatal(err)
}

Уупс, у меня есть privateKey, а остальное как сделать? @danicheeta

andrey_derma 12.10.2018 11:32
openssl_sign($param, $signature, $private_key, $algo); return htmlentities(base64_encode($signature));
andrey_derma 12.10.2018 11:32

рад мог помочь

CallMeLoki 12.10.2018 11:54

Другие вопросы по теме