单片机加密解密,有没有很好的办法来

单片机加密解密,有没有很好的办法来,第1张

芯片解密及单片机解密必须要注意的几点★凯基迪解密

(1)在选定加密芯片前,要充分调研,了解单片机破解技术的新进展,包括哪些单片机是已经确认可以破解的。尽量不选用已可破解或同系列、同型号的芯片,选择采用新工艺、新结构、上市时间较短的单片机,如可以使用ATMEGA88/ATMEGA88V,这种国内目前破解的费用只需要1万元左右;其他也可以和CPLD结合加密,这样解密费用很高,解密一般的CPLD也要1万左右。

(2)尽量不要选用MCS51系列单片机,因为该单片机在国内的普及程度最高,被研究得也最透。

(3)产品的原创者,一般具有产量大的特点,所以可选用比较生僻、偏冷门的单片机来加大仿冒者采购的难度,选用一些生僻的单片机,比如motorola单片机,目前国内会开发使用熟悉motorola单片机的人很少,所以破解的费用也相当高,从8000~3万左右。

(4)在设计成本许可的条件下,应选用具有硬件自毁功能的智能卡芯片,以有效对付物理攻击;另外程序设计的时候,加入时间到计时功能,比如使用到1年,自动停止所有功能的运行,这样会增加破解者的成本。

(5)如果条件许可,可采用两片不同型号单片机互为备份,相互验证,从而增加破解成本。

(6)打磨掉芯片型号等信息或者重新印上其它的型号,以假乱真。

(7)可以利用单片机未公开,未被利用的标志位或单元,作为软件标志位。

(8)利用MCS-51中A5指令加密,其实世界上所有资料,包括英文资料都没有讲这条指令,其实这是很好的加密指令,A5功能是二字节空 *** 作指令加密方法在A5后加一个二字节或三字节 *** 作码,因为所有反汇编软件都不会反汇编A5指令,造成正常程序反汇编乱套,执行程序无问题仿制者就不能改变你的源程序。

(9)应在程序区写上你的大名单位开发时间及仿制必究的说法,以备获得法律保护;另外写上你的大名的时候,可以是随机的,也就是说,采用某种算法,外部不同条件下,你的名字不同,比如husoon1011、jisppm1012等,这样比较难反汇编修改。

(10)采用高档的编程器,烧断内部的部分管脚,具体如何烧断,可以参考:单片机管脚烧断的方法和破解。

(11)采用保密硅胶(环氧树脂灌封胶)封住整个电路板,PCB上多一些没有用途的焊盘,在硅胶中还可以掺杂一些没有用途的元件,同时把MCU周围电路的电子元件尽量抹掉型号。

(12)对SyncMos,Winbond单片机,将把要烧录的文件转成HEX文件,这样烧录到芯片内部的程序空位自动添00,如果你习惯BIN文件,也可以用编程器把空白区域中的FF改成00,这样一般解密器也就找不到芯片中的空位,也就无法执行以后的解密 *** 作。

串口通信具体还要结合设备是否自带dll动态库的问题,某些设备内部代读取是加密的,需要通过设备厂商提供的dll动态库里提供的函数进行读取,这里只能说一下串口的 *** 作步骤,主要还是三步:

一,是初始化端口

注:设备提供的动态库一版都带有自己的初始化函数,delphi中对于端口初始化代码如下,

var

FileHand:integer;

port:string;//端口号,可以用字符赋值,例如直接赋值:'com1',如果定义为整型则对应1

begin

FileHand:=FileOpen(port,fmOpenWrite or fmShareDenyNone);

FileClose(FileHand);

if FileHand<=0 then

begin

showmessage('设备尚未就绪,请您检查设备是否连接或者电源是否打开!');

exit;

end;

AssignFile(PosPrintFile,Trim(port));

ReWrite(PosPrintFile);

end;

二,是对端口 *** 作,具体设备得根据其动态库提供的函数来 *** 作;

三,关闭端口;

如果对您有帮助,请记得采纳为满意答案,谢谢!祝您生活愉快!

额,首先,这个加密的原理要清楚。还有编译的原理要清楚。。。

第一,程序为什么会被读出来?因为编程器编程总要校验一下比较安全,保证编程可靠。所以,编程器一般都可以读程序。但是,这个被山寨哥们看上了就是大大的方便了。于是,加密位就被设计出来了。加密一下,编程器就读不出程序了。这个在编程时编程器设置项了可以选择。具体发生的事情是:编程器对器件的加密位编程。于是器件的“读”功能就被限制。只有全擦除可以连加密位一起还原。如此就达到了代码保护的作用。由于这个过程不涉及程序本身,属于对器件的“设置”。并不是靠程序执行来起作用的。所以靠编译器来加密?还是算了吧。。。

第二,编译是把由高级语言写成的源代码,翻译成“天书”的过程。这个涉及到的,仅仅是一个翻译的过程。就像说话,跟美国人说是要说“鸟语”的。但是意思是一个样的。要是这个再能加密,那么抱歉,美国人也不都是中情局的,到时候会看不懂“密电”的。

stm8具有唯一id,可以利用这个id做程序加密

例如

#define ID_ENCRYPT_EOR_RESULT_ADDRESS (0x9ff0)

#define ID_ENCRYPT_ADD_RESULT_ADDRESS (0x9ff4)

void Stm8s103EncryptDemo(void)

{

      uint32 u16IdAddress;

uint16 u32EorRslt, u16AddRslt;

   

      //千万别显式的读取ID,即要把0x4865运算成隐式的,例如此例中0x4865 = (0x1194 4) + 0x215;

      //这样,别人就算破解出了你的程序,也查找不到0x4865,这样就不能轻易的软解密,这样处理后如果要软解密,

      //一定要反汇编出来进行复杂逆向分析,难度极大,代价极高,很难搞定软加密了,达到保护产品的目的。

      gU16IdAdressVar = 0x1194;

      gU16IdAdressVar <<= 2;

      u16IdAddress = (uint16)(gU16IdAdressVar + 0x215);//0x4865

 

      //读取单片机的ID,并进行运算,具体算法可以自己定,这里只用到简单的异或及和运算

      u16EorRslt = (u16IdAddress) ^ ((u16IdAddress + 1)) ^ ((u16IdAddress + 2));

      u16AddRslt = (u16IdAddress) + ((u16IdAddress + 1)) + ((u16IdAddress + 2));

      //进行对比,如果运算结果与FLASH保存的结果不一样,说明非法,运行错误代码

      if(u16EorRslt != ((uint16)ID_ENCRYPT_EOR_RESULT_ADDRESS))

      {

              while(1);//异或算法结果不正确,进行错误分支

      }

      if(u16AddRslt != ((uint32)ID_ENCRYPT_ADD_RESULT_ADDRESS))

      {

              while(1);//和算法结果不正确,进行错误分支

      }

}

1,如果板子上有外部存储器,可以先编写一个程序,利用算法把id计算得到一些值存入外部存储器,然后再烧写真正的程序,真正的程序去校验外部存储器的数据是否合法即可

2,利用板子上按键组合,或是上电按住某些键,程序在这个时候利用算法把id计算得到一些值存入程序区(stm8为EE区),程序运行时去验证程序区数据是否正确

3,轩微编程器有软件加密的功能,编程器会读芯片id,根据算法直接改写缓冲区,达到软件加密的作用

4,读出的id通过一定算法,例如异或加上一个数,得到的数据存入flash(只运行一次,运行后标志位也存入flash),下次读到这个标志位,就不运行这个程序

以上就是关于单片机加密解密,有没有很好的办法来全部的内容,包括:单片机加密解密,有没有很好的办法来、单片机串口通信加密、51单片机怎么加密 在源代码会不会有用来加密的代码等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/9315687.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-27
下一篇 2023-04-27

发表评论

登录后才能评论

评论列表(0条)

保存