最近有学员问我,怎么把我们的程序"加密"?
我们一般接触最多的程序文件就是.c和.h为后缀名的文件。
不知道大家有没有看到过.lib为后缀名的文件,这种就是加密的源代码文件。
我们用keil开发工具就可以把我们的.c文件加密成这种.lib文件。
这样能达到以下目的:
不想让别人看到自己写的源代码,同时又想让他使用你的程序功能。
一般很多芯片原厂就是这样干的,比如说TI的蓝牙和Zigbee协议栈,虽然说是开源的,但是实际上你去看他们底层的代码,很多都是用这种方式加密的。
还有就是一些模块原厂提供模块给方案商用,比如说以前我用汉枫wifi模块的时候,他们核心的代码就是通过这种方式的。
还有就是做电子狗和导航产品的,他们那个地图库是100%加密的。
总结:一般核心技术就会这样去加密,菜鸡程序就不用加了,浪费情怀。
2.加快编译速度,比如说工程比较庞大的时候,如ST固件库,文件很多编译时间需要很长,如果打包成lib库,就能节约不少时间(网上看的,真实性自行考察)。
下面是用keil把我们代码生成.lib的方法,我用我们无际单片机编程的wifi报警主机项目按键功能模块举例。
建立一个空的工程,把你需要加密的文件添加进去。
把需要生成lib的.c文件添加进来,这我需要把我按键功能模块代码生成lib,所以添加hal_key.c。
2.打开keil的options for Target…设置。
3.选择Output选项,在该选项选择Create Library…lib
然后点ok,重新编译就行了,是不是贼简单?
4.编译没有错误以后,我们在工程目录下找到Objects文件夹。
5.我们可以看到有一个lib文件,就是我们刚刚编译生成的。
不知道大家发现没,怎么生成的名字不是hal_key而是wh01?
这个其实是根据你工程名字生成的,我们手动重命名就可以了。
6.把我们这个lib文件添加到需要用到按键功能的工程文件夹里。
这里需要注意的是,一般要把lib文件和对应.h头文件一起放到对应文件夹里面,别人使用你的函数功能,以及函数有什么参数,就是通过查看.h文件调用的。
通过hal_key.h文件,我大概知道这个源代码提供3个可以提供外部调用的函数。
一个是按键初始化hal_KeyInit(),无返回值,无形参。
一个是按键检测函数hal_KeyProc(),无返回值,无形参。
一个是函数指针注册函数hal_KeyScanCBSRegister。
如果我们需要给别人用的话,不要学我啥注释没有,我们是在视频教程里有讲每个函数的作用。
一定要有点注释,让别人知道怎么调用,有什么条件要求,不然光几个函数别人肯定一脸懵逼。
7.下面,我们就能正常使用hal_key.c的函数功能啦。
同时,别人也看不到你hal_key.c这个文件的源代码了。
最后还想跟大家说几句话。
别看封装lib代码很简单,实际是一门技术活。
主要体现在你的代码移植性写的好不好,如果移植性不好,会直接暴露你的水平。
我就碰到过很多模块厂的工程师封装以后,还需要用到全局变量来传递数据的,这种就是经验不足的人写出来的代码。
封装成lib不是什么技术,怎么能把你的代码封装完以后最小程度干涉别人的代码才是技术。