微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用 PGP (BouncyGPG) 加密大文件并在 Kotlin 中通过 SFTP (JSch) 发送

如何解决使用 PGP (BouncyGPG) 加密大文件并在 Kotlin 中通过 SFTP (JSch) 发送

我一直在尝试使用 PGP 加密大文件(为此我使用 BouncyGPG)并使用 SFTP(使用 JSch)将其发送到远程服务器。我正在使用 PipedOutputStream 和 PipedInputStream 来避免在发送到服务器之前将最终加密的文件保存在本地。我认为因此 BouncyGPG 行为不端。

谁能帮我解决这个问题?

这是我的代码

    BouncyGPG.registerProvider()

    private val bufferSize: Int = 8 * 1024

    fun sendFileSFTP(myFile: MyFile {
        PipedInputStream().use { input ->
            GlobalScope.launch {
                PipedOutputStream(input).use { output ->
                    encrypt(myFile,output)
                }
            }
            sendSFTP(input,"mysftp-directory/${myFile.filename}")
            log.info("Finished Sending $myFile")
        }
    }

    fun encrypt(myFile: MyFile output: OutputStream) {
        log.info("ENCRYPTING - $myFile")
        val pubkey = "/home/myhome/server.gpg"
        val privkey = "/home/myhome/server.secret.gpg"
        val password = "password"
        val keyring = KeyringConfigs.forGpgExportedKeys(KeyringConfigCallbacks.withPassword(password))
        keyring.addPublicKey(FileReader(File(pubkey)).readText().toByteArray(charset("US-ASCII")))
        keyring.addSecretKey(FileReader(File(privkey)).readText().toByteArray(charset("US-ASCII")))


        BouncyGPG.encryptToStream()
            .withConfig(keyring)
            .withStrongalgorithms()
            .toRecipients("contact@myserver.com")
            .andDoNotSign()
            .binaryOutput()
            .andWriteto(output)

        val filepath = Paths.get(myFile.path,myFile.filename)
        BufferedInputStream(FileInputStream(filepath.toString())).use { input ->
            input.copyTo(output,bufferSize)
        }

        log.info("FINISHED ENCRYPTING - $myFile")
    }

    fun sendSFTP(inputStream: InputStream,dest: String) {
        log.info("Sending $dest")
        var jsch = JSch()
        jsch.setKNownHosts(properties.kNownHosts)

        val jschSession: Session = jsch.getSession(properties.sFTPUsername,properties.sFTPHost,properties.sFTPPort)
        jschSession.setPassword(properties.sFTPPassword)
        jschSession.connect()
        val channel = jschSession.openChannel("sftp") as ChannelSftp
        channel.connect()

        channel.put(inputStream,dest)
    }

我假设 BouncyGPG 由于没有关闭而没有播放我的文件(我相信我在某处读到它只在输出关闭后对文件进行签名,但据我所知,kotlin 会关闭已经输出给我了。我错过了什么吗?

谢谢

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。