Unity游戏项目开发中如何做资源加密

Unity的游戏很容易被人反编译出来,然后再重新打包发布,把自己辛辛苦苦开发的游戏,抄写的一丝不挂。很多项目要求要做好资源加密,Unity中如何做好资源加密呢?本文給大家分享加密算法+资源打包整合思路:

对啦!这里有个游戏开发交流小组里面聚集了一帮热爱学习游戏的零基础小白,也有一些正在从事游戏开发的技术大佬,欢迎你来交流学习。

游戏资源包如何选择加密算法

游戏资源包加密的第一件事情就是选一个什么样的加密/解密算法,比较不容易被人破解。我们如何来选择呢?很遗憾的告诉大家,没有任何一个保险的加密解密算法是安全的。杠精第一时间就会来反驳,这怎么可能,我加密了他怎么破解?游戏资源加密注定了加密算法不能用太耗时的加密算法。接下来我们来看下不同加密算法是如何被破解的。

(1) 使用标准库实现的加密解密算法,比如使用encrypt加密/解密算法。这里有个问题,我们会有一个密钥用来解密,密钥一般游戏都写死到代码里。这种破解太简单了,密钥写死在代码里,基本都是字符串等,静态分析代码找到密钥对应的字符串,有了密钥,你用的是标准库,一下加密资源就破解了,分分钟你的资源就被破解了。

(2) 使用自己实现的加密解密算法,比如,采用二进制亦或来做加密解密,比如,加密定一个二进制掩码mask, 让每个字节都异或这个mask,得到一个新的数据,这样资源就不能被直接识别出来,使用资源得时候,再把加密数据异或一次mask在解密回来到项目中使用。这种破解稍微蛮烦写,需要自己反编译你的解密代码,同时还要找到你的解密密钥key。但是本质也比较容易破解。

加密/解密算法示意如下:

所有从上面分析来看想要不被破解,几乎是很难,就看破解的代价。你这个游戏是否值得。一般我们的目标就是不要让人通过Unity反编译工具就能直接让我们的游戏直接反编译出Unity项目工程,然后重新编译打包发布就可以了。解密算法要快,注定他不会太复杂,密钥单一的放客户端或是网络,注定能获取到。

Assetsbundle资源包的加密与解密

(1) 新建一个类,继承自FileStream, 重写Read/Write函数。代码如下:

using System.IO;

public class MyStream : FileStream {
    const byte KEY = 40; // 密钥mask: 0010 1000

    public MyStream(string path, FileMode mode, FileAccess access, FileShare share, int bufferSize, bool useAsync) :
                               base(path, mode, access, share, bufferSize, useAsync) {

    }

    public MyStream(string path, FileMode mode) : base(path, mode) {

    }

    // 重载读接口,一边读,一遍解密;
    public override int Read(byte[] array, int offset, int count) {
        var index = base.Read(array, offset, count);

        for (int i = 0 ; i < array.Length; i++) {
            array[i] ^= KEY;
        }
        return index;
    }

    public override void Write(byte[] array, int offset, int count) {
        // 重载写接口,先加密再写入;

        for (int i = 0; i < array.Length; i ++) {
            array[i] ^= KEY;
        }
        base.Write(array, offset, count);
    }
}

(2) 修改ab包打包工具脚本,再对生成的ab包资源加密一次,打包加密脚本如下:

[MenuItem("Tools/BuildAB")]
static void BuildAB()
{
    …
    // for循环遍历里面的打包后的每个资源Ab包,然后调用进行加密。
    foreach (var name in manifest.GetAllAssetBundles())
    {
        var uniqueSalt = Encoding.UTF8.GetBytes(name);
        var data = File.ReadAllBytes(Path.Combine(Application.streamingAssetsPath, name));
        using (var myStream = new MyStream(Path.Combine(Application.streamingAssetsPath, "encypt_" + name),FileMode.Create))
        {
            myStream.Write(data, 0, data.Length); // 触发MyStream中我们重写的write函数的调用, 完成数据加密
        }
    }
    AssetDatabase.Refresh();
}

(3) 解密的时候,读取ab包,使用函数AssetsBundle.LoadFromStream来加载,而这个会触发Stream在Read读数据接口调用,就可以进入我们重载的Read接口,来做解密。代码如下:

var fileStream = new MyStream(Application.streamingAssetsPath + "/encypt_myab.unity3d", FileMode.Open, FileAccess.Read, FileShare.None, 1024 * 4, false))
{
    var myLoadedAssetBundle = AssetBundle.LoadFromStream(fileStream); // 触发MyStream中的Read调用,来解密数据。
}

今天的分享就到这里了,关注我们,可以学习更过Unity进阶的一些教程。

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Unity软件的加密方式主要是对Assembly-CSharp.dll进行加密,这样可以保护Unity的主要代码逻辑不被反编译,以保护软件开发商的合法权益。同时,可以使用工具如DS Protector对Unity软件资源文件(如.ress和resources)进行加密,以防止这些资源被非法提取。 一种常用的对称加密体制是DES(Data Encryption Standard),它具有高安全性、低计算开销和快速处理速度的特点。特别适合用于对大量数据和大文件进行加密保护。DES加密算法的基本原理是将输入的明文数据按照一定规则进行加密转换,生成密文数据。 Unity软件加密的目的是为了保护软件的安全性,防止非法的访问和使用。虽然DES加密算法本身具有较高的安全性,但并不能保证绝对的安全性。然而,由于DES加密算法的强大健壮性和耗时的穷举法破解难度,攻击者很难通过对加密算法的破解来获取网络游戏数据。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [以unity3d为例解读:游戏数据加密](https://blog.csdn.net/flyTie/article/details/126068128)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值