ImageVerifierCode 换一换
格式:DOCX , 页数:34 ,大小:468.03KB ,
资源ID:994064      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-994064.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(基于8086的电子密码锁技术报告.docx)为本站会员(b****1)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

基于8086的电子密码锁技术报告.docx

1、基于8086的电子密码锁技术报告基于8086的电子密码锁技术报告 (1)、开始执行时数码管每一位都显示“米”,点输入密码数码管只有第一位显示“米”,点击数字键进行数字选择;(2)、按下“确认”键后跳到第二个数字,操作同第一步;(3)、当四个密码选中完毕,按下“确认输入”键,显示输入的密码; (4)、按下“开锁”键,若密码正确,同时显示*YES,密码锁打开;(5)、按下“开锁”键,若密码错误,则显示ERRO,密码锁不能打开,按下“输入密码”键,即可重新输入密码。更改密码: (1)、在显示*YES时,按下“更改密码”键后,输入新的四位密码; (2)、按下“确认输入”键,显示新密码,按下“确认”键,

2、即可设定新密码。错误警报: 若输入错误密码超过5次,警报会自动响起,只有再次输入正确密码后方可解除警报。第2章 硬件电路设计2.1相关芯片简介1. 8255第一片8255定义A.B.C口都为输出状态,A.B口控制数码管的输入口,对应相应的段码表,来显示。C口的PC0,PC1经过2-4译码器,来激活数码管1,2,3,4通道,并采用00,01,10,11,循环输出的方式,使数码管通道循环激活,实现动态显示。第二片8255定义A,B,C口都为输入状态,对应输入相应的按钮状态,对应相应的程序,实现相应功能。2. 8253使用0通道,方式3,对输入的始终信号分频,当输入密码次数大于5次时,初始化8253

3、,并发出警报提示声。当输入密码正确后,激活1通道,警报提示声接触。3. 2-4译码器由于8086运行速度过快,数码管动态显示出现显示不全的现象,因此PC0,PC1输出经过2-4译码器之后,再激活数码管,起到缓冲作用。4. 16位数码管16位数码管的数码管,由16个引脚控制,低电平有效,其中A-H控制外圈0,K-M控制内部* S1-s4是通道控制,高电平有效。2.2 仿真电路总体设计 本实验设计中,硬件部分涉及到了8086CPU、可编程并行接口8255A,并配合74LS373锁存器、74LS245缓冲器、74LS138译码器等基本元器件,实现了设想的电子密码锁。8255A:如图2-6,8255A

4、的D0D7端口与CPU数据线ADOAD7相接,CPU通过控制线的片选、读、写信号接口对8255A进行读、写与片选操作。外设接口端的A0-A7八个开关连接245的A0-A7端口,将外设信息传送到245中,键入密码输入、密码确定、修改密码等多种功能。图2-6 开关功能如图2-7,A口的PA0-PA7端口通过锁存器与数码管相连用于外圈显示,B口的PB0-PB7端口通过74LS373锁存器与数码管进行连接用于内部“米”字格的显示。第3章 软件编程设计3.1系统概述密码锁是一种通过密码输入来控制电路或芯片工作,从而控制机械的开关和闭合,完成开锁闭锁任务的电子产品。它的种类很多,有简易的电路产品,也有基于

5、芯片的性价比较高的产品。现在运用较广的电子密码锁是以芯片为核心,通过编程来实现的,其性能和安全性已大大超过机械锁。其特点是保密性好,随机开锁成功率几乎为零。密码可变,用户可随时更改密码,防止密码被盗,同时也可以避免因人员的更替而使锁的密级下降。无活动零件,不会磨损,寿命长。使用灵活性好,不像机械锁必须佩带钥匙才能开锁。3.2 程序流程图设计密码的输入与判定 位数+1 N Y N Y图3-1 密码的输入与判定密码的更改 位数+1 N Y N Y图3-2 密码的更改3.3 按键控制(1)、控制字 给8255A输入端口控制字:void fun82531() _asm mov dx, 0x8006 m

6、ov al, 0x37 out dx, al outp(GATE0,0x02); outp(GATE0,0x00); void fun82532() _asm mov dx, 0x8006 mov al, 0x77 out dx, al outp(GATE0,0x99); outp(GATE0,0x99); (2)、密码键入控制整个过程中主要是对是否有按键信息输入进行扫描判断,并将所得信息与灯管编号进行比对,确定所选择要键入数字的灯管。当目前的灯管数字被选出后,自动跳到下一个灯管,直到四位数字全部选择完毕。 3.4 字符动态显示四位密码选出后,显示四位选定数字,然后检测密码正确性,8255A通

7、过端口A、B、C读取指令,根据检测结果,密码正确则输出代码显示*YES,错误则显示ERRO。 见附录:检测密码正确性更改密码,键入“更改密码”控制字后,与输入密码的流程相同,先选择灯管,待选定数字后跳至下一个,直到四位数字全部选定,然后键入“确认更改”指令,则密码更改成功。见附录:密码更改第4章 系统实现4.1 proteus仿真实验图4-1 Proteus仿真图如图4-1,为本实验的Proteus仿真模拟图,整个实验共用到8086CPU一个、74LS245一个、可编程并行接口8255A一个,74LS273锁存器三个、74LS138译码器一个、数码管一个、与非门两个、开关八个、电阻八个。第5章

8、 与军事方面的联系电子密码锁对于军事方面有很大意义,应用也十分广泛。部队的许多地方都比较重要,比如弹药库、武器库,和一些存放有关于军事机密的地方等,除了要有人看管以外,还要上锁,而对于普通的锁来说,电子密码锁无疑是较为便捷和安全的。用钥匙解锁的话,钥匙可能丢失,也可能被人偷去复制,安全性较低,而电子密码锁不用携带钥匙,只需要记住密码,也不用担心丢失和被他人窃取,在更换密码上电子密码比较方便;在外面的只有密码输入装置,遇到暴力破解时也能保证物品的安全。第6章 结论6.1 设计总结通过对电子密码锁的设计,从设计硬件电路到编写代码,再到对程序的调试,在整个的设计过程中学到了很多。例如,我们用到了82

9、55A的并行接口,将二进制的控制信息传入8086CPU中处理,选择对密码是否正确进行调整。与此同时,我们又通过这次产品的设计加深了对硬件知识的理解以及常用芯片功能的掌握。在使用8255A和8253的时候,要对其进行初始化,这初始化程序的编写,有助于对这些接口芯片的工作原理的理解。总之,在实验中自己动手,把理论知识用于实践,从中能够学到很多。6.2 收获与体会通过这一个多月以来对电子密码锁的硬件电路的设计,以及对软件程序的编写,我们又对计算机硬件技术基础这门课程有了更深一层的理解。与此同时,我们还有如下收获:首先,我们能熟练掌握计算机硬件技术知识,其中包括硬件电路设计和软件编程设计等内容。计算机

10、硬件技术基础是比较难学的科目,尤其是对那些没有过编程基础的学员来说,刚开始接触时感觉力不从心。但是,通过设计这个电子密码锁,我组成员都能对硬件设计以及软件编程熟练掌握,并且能实现原计划的功能,效果比较显著。其次,增强了我们组员之间的团结协作的能力。通过实验,我们明白了团队力量的强大,只有一个团队能够齐心协力、合理分工,工作才能有条不紊的高效开展。最后,我们能够将自己设计的东西应用于实际生活当中,充分体现了它的价值。作为军校学员,我们有责任去开发设计有利于部队生活实际的东西,这也是我们每一个学员的义务所在。6.3 缺点与不足虽然在这次电子密码锁的制作中我们收获了很多,但是也不乏问题存在。首先,刚

11、开始的时候分工不明确,导致制作进程比较缓慢。由于刚接触一门全新的课程,再加上对程序的编写不是很熟悉,所以大家都不知道从何入手,没有明确的分工。随着教员对硬件知识的讲解,再结合平时的小组讨论与自我学习,大家对C语言基本理解。于是开始分配任务,有主攻硬件设计的,有软件编程的,也有PPT制作和论文编写的,以此提高了我们的效率。其次,由于我们知识积累不足,导致大家在制作中遇到很多困难,期出现厌烦心理,抱怨声音较多,甚至出现了分歧与争吵。当然,对于一个团队来说,出现矛盾是在所难免的,这时候作为组长更应该起到稳定军心的作用。大家在一起,从头来过,寻找解决问题的办法,一起攻克难关。最后,是制作时间比较少。由

12、于我们身处军校这个特殊的环境,平时白天进行文化课的学习,下午又有体能训练,所以自主时间比较少。我们平时的制作也只能利用晚自习、晚加班的时间进行,这同样也是影响制作进程的原因之一。程序:#define GATE0 0x8000 #define GATE1 0x8002 #define GATE2 0x8004 #define GATECOM 0x8006#define IOA1 0xc000#define IOB1 0xc002#define IOC1 0xc004#define IOCC1 0xc006#define IOA2 0xD000#define IOB2 0xD002#define

13、IOC2 0xD004#define IOCC2 0xD006char err1=0CH, 38H,38H,00H;char err2=77H, 67H,67H,0FFH;char cs=0b00000000,0b00000001,0b00000010,0b00000011;char num1=00H,0f3h,88h,0c0h,73h,44H,04H,0F0H,00H,40H;char num2=0ffh,0ffh,77h,77h,77h,77h,77h,0ffh,77h,77h;char yes1=0FFH,0FFH,0CH,44h,;char yes2=00H, 0DAH,77H,77h

14、;void outp(unsigned int addr, char data)/ Output byte to port _asm mov dx, addr mov al, data out dx, al char inp(unsigned int addr)/ Input byte from port char result; _asm mov dx, addr in al, dx mov result, al return result; / void fun82531() _asm mov dx, 0x8006 mov al, 0x37 out dx, al outp(GATE0,0x

15、02); outp(GATE0,0x00); void fun82532() _asm mov dx, 0x8006 mov al, 0x77 out dx, al outp(GATE0,0x99); outp(GATE0,0x99); void delay(int s) unsigned int i,j; for(i=0;is;i+) for(j=0;j1000;j+); / 大约s=20 延时1s /* void yes() char tmp; int i; char yes1=0FFH,0FFH,0CH,44h,; char yes2=00H, 0DAH,77H,77h; char cs

16、=0b00000000,0b00000001,0b00000010,0b00000011; tmp=inp(IOA2); while(tmp=0xffed) tmp=inp(IOA2); for(i=0;i4;i+) outp(IOC1,csi); outp(IOA1,yes1i); outp(IOB1,yes2i); delay(1); /* void fun82551() _asm mov dx, 0xc006 mov al, 0x80 out dx, al void fun82552() _asm mov dx, 0xD006 mov al, 0x9b out dx, al /*void

17、 err() / 密码错误 char tmp; int i; char err1=0CH, 38H,38H,00H; char err2=77H, 67H,67H,0FFH; char cs=0b00000000,0b00000001,0b00000010,0b00000011; tmp=inp(IOA2); while(tmp=0xffed) tmp=inp(IOA2); for(i=0;i4;i+) outp(IOC1,csi); outp(IOA1,err1i); outp(IOB1,err2i); delay(1); /* void chushihua(int r) / 复位 int

18、i; if(r=1) for(i=0;i4;i+) outp(IOC1,csi); outp(IOA1,num10); outp(IOB1,num20); delay(1); char xianshi() char tmp; char result; tmp=inp(IOB2); if(tmp=0xfffe)/0 outp(IOA1,num10); outp(IOB1,num20); result=0; if(tmp=0xfffd)/1 outp(IOA1,num11); outp(IOB1,num21); result=1; if(tmp=0xfffb) outp(IOA1,num12);

19、outp(IOB1,num22); result=2; if(tmp=0xfff7) outp(IOA1,num13); outp(IOB1,num23); result=3; if(tmp=0xffef) outp(IOA1,num14); outp(IOB1,num24); result=4; if(tmp=0xffdf) outp(IOA1,num15); outp(IOB1,num25); result=5; if(tmp=0xffbf) outp(IOA1,num16); outp(IOB1,num26); result=6; if(tmp=0xff7f) outp(IOA1,num

20、17); outp(IOB1,num27); result=7; tmp=inp(IOC2); if(tmp=0xfffe) outp(IOA1,num18); outp(IOB1,num28); result=8; if(tmp=0xfffd) outp(IOA1,num19); outp(IOB1,num29); result=9; return result; /* char change(int c) / 单纯的更改密码的函数 char result; char tmp; outp(IOC1,csc); outp(IOA1,yes10); outp(IOB1,yes20); tmp=i

21、np(IOA2); while(tmp!=0xfff5) tmp=inp(IOA2); result= xianshi(); return result; /直接传出去改过之后的哪位数字,不管是更改密码还是输入密码,只管输出 /*char genggaimima() /更改密码 int c=0; char i1; i1= change(c); return i1; / 要求更改密码,直接更改第一位,并输出更改之后的第一位密码是多少 i=1,可以更改密码 /*char huanwei(char c) /换位 c+; delay(50); return c; /传出去换位之后的位 /* /*cha

22、r shurumima() /第一位输入密码 输入密码 int c=0; char s1;/输入的第一位密码 s1= change(c); return s1; /传出去第一位输入的密码 / void querengg(char shuru) / 显示输入之后的密码 ffdf int i,j,m; for(j=0;j7;j+) for(i=0;i4;i+) m=shurui; outp(IOC1,csi); outp(IOA1,num1m); outp(IOB1,num2m); delay(1); int panduan1(char shuru,char mima)/判断 开锁 I为1,可以更

23、改密码 I为0不允许更改密码 int i; if(shuru0=mima0&shuru1=mima1&shuru2=mima2&shuru3=mima3) /判断输入的密码和更改的密码是否一样 yes(); i=1; else err(); i=0; return i; int panduan2(char shuru,char mima,int t)/判断 错误超过6次,警报 t为 错误密码次数 if(shuru0=mima0&shuru1=mima1&shuru2=mima2&shuru3=mima3) /判断输入的密码和更改的密码是否一样 yes(); t=0; else err(); t

24、+; return t; / void main(void) int i1=0,i2=1,i3=2,i4=3; int s1=0,s2=1,s3=2,s4=3; int r=1; /变量R非常重要,只有当R=1时,才可以修改密码,初始化密码,在判断密码中,会返回一个R,得知R=1or0. !亮点 int t=0; char mima100=0,0,0,0; /这两个数组是亮点 char shuru100=0,0,0,0; char tmp; int c1=0; /更改密码的led位置 !亮点 int c2=0; /输入密码的led位置 fun82551(); fun82552(); while

25、(1) tmp=inp(IOA2); if(tmp=0xfffC&r=1) / 显示0000 chushihua(r); mima0=0; mima1=0; mima2=0; mima3=0; if(tmp=0xffbd&r=1) / 按更改密码 开始改密码 r=1时才能更改密码 mimai1=genggaimima(); c1=huanwei(c1); mimai2=change(c1); c1=huanwei(c1); mimai3=change(c1); c1=huanwei(c1); mimai4=change(c1); c1=0; int i,j,m; for(j=0;j25;j+) for(i=0;i4;i+) m=mimai; outp(IOC1,csi); outp(IOA1,num1m); outp(IOB1,num2m); delay(1);

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2