我正在使用Moar.现在可以创建perl6可执行文件吗?
我在machineA上开发了源代码,我想在machineB上运行它,这比machineA快3倍,但我不希望机器B上的人能够查看源代码.
或者我是否必须更改为Java VM?
如果无法创建perl6可执行文件,保护公司/部门知识产权的最佳方法是什么?
非常感谢你 !!!
lisprog
对于简单的东西,如果您自己在 machineB 上运行它,您可以尝试解密程序中的源代码或 STDOUT,然后将其提供给 perl6。加密和解密有很多选项,例如一次性密码本、gpg,甚至可以通过 machineA 上的套接字安全地读取内容。这是使用 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
Run Code Online (Sandbox Code Playgroud)
至于在 shell 级别使用一次性密码本进行加密,将使用一个脚本(需要 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
Run Code Online (Sandbox Code Playgroud)
所以幕后的流程是这样的,
当您需要共享文件时,这很有用(只要您能找出安全密钥交换部分,就可以使用其他公钥)
至于程序操作,据我所知,生态系统中还没有任何与此类似的模块,但是您可以从这里汲取灵感来构建您自己的帮助器类/模块。
| 归档时间: |
|
| 查看次数: |
206 次 |
| 最近记录: |