提问者:小点点

在Perl6中创建可执行文件


我正在使用Moar。现在可以创建perl6可执行文件了吗?

我在机器A上开发了源代码,我想在机器B上运行它,它比机器A快大约3倍,但我不希望机器B上的人能够查看源代码。

还是要换JavaVM?

如果无法创建perl6可执行文件,保护公司/部门知识产权的最佳方法是什么?


共1个答案

匿名用户

对于简单的东西,如果你自己在机器B上运行它,你可以尝试解密程序中的源代码或STDOUT,然后将其提供给perl6。加密和解密有许多选择,例如,一次性垫、gpg,甚至通过机器A的套接字安全地读取内容。这是一个使用zip和unzip的概念证明示例,

cat my.p6
for 1 .. 5 { say rand }
zip -e my.zip my.p6
Enter password:
Verify password:
adding: my.p6 (stored 0%)
unzip -p my.zip | perl6
[my.zip] my.p6 password:
0.6868457931159548
0.3818693072902063
0.26339483730150215
0.03617574596367301
0.1992317319783774

至于在shell级别使用一次性pad进行加密,将使用脚本(需要openssl和ssh),

./sshencdec.sh -p ~/.ssh/id_rsa.pub < my.p6 > my.p6.enc
./sshencdec.sh -s ~/.ssh/id_rsa  < my.p6.enc | perl6
Enter pass phrase for /home/david/.ssh/id_rsa:
0.4554567534399926
0.5215978159072545
0.5188661477620019
0.4928945548121154
0.2916414959794953
cat my.p6.enc
-- encrypted with https://git.e.tern.al/s2/sshencdec
-- keys
-- key
M32P8T5hAbkozzu9Hsb0UxaHMIowBnm5SGya1JdVRKM85NrsmMaO+JVICdpNCACu
0onf3xIDIdl6IRiLRmbrrG2qOHqYSqHXLLs4Yt7530IvGiDyxpGeygJwt35+PZ4T
KH6FMluenkvkHufsY1xRC2PM8kzQ0xtx9ThVNkupQavVN3SOHaMxVFZUqJCuInFl
Y8e6iMyoF7NfQ4ekUwOtpJtFjB5DzMepxg+iAetTV2E2kwAq5qUTrmkzSTd38b+X
YzdeYmngMjBPzMZ/nrBT4cE2kAYyIGUwTDMa5UsClUUBBAN6Igfxn5O6ozlq9FXk
IIujhfgAn64U2DfcYHCZ2w==
-- /key
-- /keys
U2FsdGVkX18ObEPup0W1+45UewyKoUftMzn+dUDRQp9mDCzJ0/7cVYTe6zNJINIU

所以幕后的流程是这样的,

  • 使用强密码(脚本使用AES 256)使用pad将SECRET加密到eci. enc
  • 使用非对称加密保护PAD以生成PAD. enc(本例中SSHRSA)
  • 现在您将需要seci. enc、PAD.enc和私钥密码短语来执行必要的解密(脚本方便地将前两个合并到一个文件中)

当您需要共享您的文件时,这很有用(使用他人公钥,只要您能弄清楚安全密钥交换部分)

至于在程序操作中,AFAIK在生态系统中还没有类似的模块,但是你可以从这里吸取想法来构建你自己的帮助类/模块。