如何实现代码加密

1、代码为什么要加密?

只要有程序员在,在源代码可读的情况下,无论多么复杂的系统,总有人可以破解其中的奥妙。

就比如Windows Server 2008的激活(没有源代码的情况),最新版的Windows Server 2008需要联机才能激活,即使这样,也有人可以做出注册机。没有源代码的Windows尚且如此,那有源代码就更容易破解了。 
 

人都是有好奇心的 正如那句歌词 :得不到的更加爱、太容易来的就不理睬   所以为了抄袭,为了原创,代码要加密。

下面是一个简单的代码加密,利用base64加密实现代码加密。

function encode_file_contents($filename) {
    $type=strtolower(substr(strrchr($filename,'.'),1));
    if ("php" == $type && is_file($filename) ) { // 如果是PHP文件 并且可写 则进行压缩编码
        $contents = file_get_contents($filename); // 判断文件是否已经被编码处理
        $contents = php_strip_whitespace($filename);

        // 去除PHP头部和尾部标识
        $headerPos = strpos($contents,'<?php');
        $footerPos = strrpos($contents,'?>');
        $contents = substr($contents, $headerPos + 5, $footerPos - $headerPos);
        $encode = base64_encode(gzdeflate($contents)); // 开始编码
        $encode = '<?php'."\n eval(gzinflate(base64_decode("."'".$encode."'".")));\n\n?>";

        return file_put_contents($filename, $encode);
    }
    return false;
}
public function demo()
{
    $filename = '../app/api/controller/Test.php';    //需要加密的文件完整路径
    $aa = $this->encode_file_contents($filename);
    k($aa);die;
    echo "OK,加密完成!";
}

目前也有好多代码加密的软件,大家也可以尝试尝试

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是Java中使用sm2进行加密的示例代码: 首先需要引入Bouncy Castle库: ```java import org.bouncycastle.jce.provider.BouncyCastleProvider; import java.security.Security; ``` 然后可以使用以下代码进行加密: ```java // 添加Bouncy Castle作为加密提供者 Security.addProvider(new BouncyCastleProvider()); // 生成随机的 SM2 密钥对 KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("EC", "BC"); keyPairGenerator.initialize(ECNamedCurveTable.getParameterSpec("sm2p256v1")); KeyPair keyPair = keyPairGenerator.generateKeyPair(); // 加密的明文 byte[] plaintext = "Hello World!".getBytes(); // 将公钥序列化为字节串 byte[] serializedPublicKey = keyPair.getPublic().getEncoded(); // 将字节串格式的公钥反序列化为公钥对象 X509EncodedKeySpec publicKeySpec = new X509EncodedKeySpec(serializedPublicKey); KeyFactory keyFactory = KeyFactory.getInstance("EC", "BC"); PublicKey publicKey = keyFactory.generatePublic(publicKeySpec); // 生成随机的对称密钥 KeyGenerator keyGenerator = KeyGenerator.getInstance("AES", "BC"); keyGenerator.init(256); SecretKey symmetricKey = keyGenerator.generateKey(); // 使用公钥加密对称密钥 Cipher cipher = Cipher.getInstance("SM2", "BC"); cipher.init(Cipher.ENCRYPT_MODE, publicKey); byte[] encryptedSymmetricKey = cipher.doFinal(symmetricKey.getEncoded()); // 将加密后的对称密钥和明文使用 AES-CBC 算法进行加密 byte[] iv = new byte[16]; // 使用全零向量 AlgorithmParameterSpec ivSpec = new IvParameterSpec(iv); cipher = Cipher.getInstance("AES/CBC/PKCS5Padding", "BC"); cipher.init(Cipher.ENCRYPT_MODE, symmetricKey, ivSpec); byte[] ciphertext = cipher.doFinal(plaintext); // 输出加密结果 System.out.println("加密后的对称密钥:" + DatatypeConverter.printHexBinary(encryptedSymmetricKey)); System.out.println("加密后的密文:" + DatatypeConverter.printHexBinary(ciphertext)); ``` 需要注意的是,上述代码中使用了随机生成的 SM2 密钥对和对称密钥,实际应用中需要使用安全的密钥生成方式。同时,加密过程中使用的 AES-CBC 算法需要指定一个随机的初始化向量 iv,此处使用全零向量仅为示例,实际应用中需要使用安全的随机数生成方式来生成 iv。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值