Создавайте объемы с помощью Veracrypt

Попытка передать инструкции командной строки go для запуска veracrypt, но она получает статус выхода 1 или не выдает ошибку и не создает запрошенный том.

func main() {
    cmd := exec.Command("veracrypt",
        "-c", "/home/user/test/samplevolume.vcrypt",
        "--volume-type", "normal",
        "--filesystem", "FAT",
        "--hash", "SHA256",
        "--encryption", "AES",
        "--size", "10M",
        "--pim", "1234",
        "-k", "",
        "--random-source", "/home/user/test/README.md")

    var out bytes.Buffer
    var stderr bytes.Buffer
    cmd.Stderr = &stderr

    stdin, err := cmd.StdinPipe()
    if err != nil {
        fmt.Println(fmt.Sprint(err))
    }

    go func() {
        defer stdin.Close()
        err = cmd.Run()
        // io.WriteString(stdin, "1234")
        // io.WriteString(stdin, "y")
        // io.WriteString(stdin, "1234")
    }()

    if err != nil {
        fmt.Println(fmt.Sprint(err) + ": " + stderr.String())
        return
    }
    fmt.Println("Result: " + out.String())
    // outin, err := cmd.CombinedOutput()
    // if err != nil {
    //  log.Fatal(err)
    // }

    // fmt.Printf("%s\n", outin)
}

Часть с комментариями - другой подход, который я использовал, который приводит к состоянию выхода 1.

Причина передачи трех строк в конце "1234", у, "1234" заключается в том, что мы хотим ввести пароль в интерактивном режиме.

Код не заканчивается созданием файлов veracrypt.

Вот командная строка для veracrypt, которую мы пытаемся вызвать с помощью golang.

veracrypt -c ~/test/samplevolume.vcrypt --volume-type normal --filesystem FAT --hash SHA256 --encryption AES --size 10M --pim 1234 -k= --random-source ~/test/README.md

Примечание: все на Linux, если это имеет значение.

Изменить: Кроме того, я новичок в golang, извините, если я сделал очевидную ошибку.

2 ответа

Решение

Поэтому я понял, что я делаю не так. Я должен был использовать cmd.Start и cmd.Wait. так вот исправленная версия. Эта версия также может принимать пользовательский ввод правильно.

func main() {
    cmd := exec.Command("veracrypt",
        "-c", "/home/user/test/samplevolume.vcrypt",
        "--volume-type", "normal",
        "--filesystem", "FAT",
        "--hash", "SHA256",
        "--encryption", "AES",
        "--size", "10M",
        "--pim", "1234",
        "-k", "",
        "--random-source", "/home/user/test/README.md")

    var out bytes.Buffer
    var stderr bytes.Buffer
    cmd.Stderr = &stderr

    stdin, err := cmd.StdinPipe()
    if err != nil {
        fmt.Println(fmt.Sprint(err))
    }

    go func() {
        defer stdin.Close()
        err = cmd.Start()
        io.WriteString(stdin, "1234\n")
        io.WriteString(stdin, "y\n")
        io.WriteString(stdin, "1234\n")
    }()

    if err != nil {
        fmt.Println(fmt.Sprint(err) + ": " + stderr.String())
        return
    }

    err = cmd.Wait()
    if err != nil {
        fmt.Printf("Command finished with error: %v", err)
    }

    fmt.Println("Result: " + out.String())
}

Вы использовали символ тильды ~ в ваших путевых именах, но это недопустимый символ в начале пути Unix.

Скорее, некоторые оболочки заменяют тильду на путь к домашнему каталогу пользователя перед передачей его операционной системе.

Поскольку вы не используете оболочку, вы должны сами указать каталог. Вы не можете использовать тильду в начале пути.

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