太实用了!自己动手写软件——密码验证器的界面实现
在之前的篇幅中,我们已经知道了我们想要编写的软件的输入输出参数。
软件输入参数:
- 服务器IP
- 服务器端口
- 协议类型
- 用户名(从密码字典中读取,无需软件界面展示)
- 密码(从密码字典中读取,无需软件界面展示)
软件输出参数:
- 破解结果:成功时展示正确的用户名密码,失败时返回失败提示
我们今天的目标很简单,就是先把软件的界面设计和写出来,并不关心每一个按钮和输入框之后的功能实现。我设计一个这样的界面(极其简单,只是实现功能)
代码讲解
之前我就讲过,我们进行tkinter编程,就好像在一块画布上画画。今天学习学这个界面的时候,我想完善一下我之前的内容。我们进行tkinter编程,应该是就好像在一块画布上进行贴画。咱们后面一一道来。
首先我们需要拿了一张画布,下面就是我们摆好画布的操作。
window.title("密码破解工具") # 窗口标题
window.geometry("300x250")
接下来我一开始尝试直接在这块画布上使用pack方法画画,我发现每一个方块的位置并不像我预期的一样摆放整齐,它可能是这样的
也有可能是这样的,总之十分诡异。很难使用pack方法摆放整齐。
后来我发现了之前我漏掉一个非常重要的分隔组件——Frame。这个东西就是一个框架,我们可以选择将组件贴在框架内,这样组件的位置就比较容易控制。这个就是我前面说是在画布上进行贴画的说法。于是我的设计图改成了这样子。
改成这样之后,页面编写就方便多了。
先在左边画一个大框架
frame = tkinter.Frame(window)
frame.pack(side='left')
然后在左边的框架内画出服务器地址的框架和内容
#服务器IP提示标签、输入框
frame_ip = tkinter.Frame(frame)
frame_ip.pack(side='top')
label_ip = tkinter.Label(frame_ip,height=2,width=10,text="服务器地址")
label_ip.pack(side='left')
entry_ip = tkinter.Entry(frame_ip)
entry_ip.pack(side='right')
接着我们在左边框架内再画一个服务器端口的框架和内容
#服务器端口提示标签、输入框
frame_port = tkinter.Frame(frame)
frame_port.pack(side='top')
label_port = tkinter.Label(frame_port,height=2,width=10,text="服务器端口")
label_port.pack(side='left')
entry_port = tkinter.Entry(frame_port)
entry_port.pack(side='right')
然后我们再在左边框架内再画一个协议的框架和内容,由于协议是多个选择中选择一个,所以我们使用了一个Listbox组件,御用列举出多个协议。
# 协议提示标签、输入框
list_pro = ['POP3', 'SMTP', 'IMAP', 'FTP', 'SSH', 'Oracle', 'MySql', 'SQL Server']
frame_pro = tkinter.Frame(frame)
frame_pro.pack(side='top')
label_pro = tkinter.Label(frame_pro,height=2,width=10, text="协议类型")
label_pro.pack(side='left')
listbox_pro = tkinter.Listbox(frame_pro)
i = 0
for item in list_pro:
listbox_pro.insert(i, item)
i += 1
listbox_pro.pack(side='left')
这样我们左边的内容就完成了,接下来我们把右边的提交按钮完成,提交按钮中包含回调函数,需要获取服务器IP、服务器端口和选择的协议内容。
#新建一个提交按钮
button = tkinter.Button(window,text="提交",height=15,width=15,command=lambda:[gettext(entry_ip,entry_port),get_select(listbox_pro,list_pro)])
button.pack(side='right')
接着我们把菜单按钮也写一些,菜单按钮应该也是包含了回调函数去执行我们明天需要完成的密码破解函数。
Menubar = tkinter.Menu(window)
Menubar.add_command(label="开始破解", command=lambda :mimapojie(dic_list['server_ip'], dic_list['server_port'],dic_list['pro']))
Menubar.add_command(label="退出", command=window.quit)
window.config(menu=Menubar)
实现效果
最终程序执行起来之后软件页面是这样的,是不是还是比较整齐,和我们的设计效果也是一致的。
今天的任务已经完成,明天我们再来看看如果将这些按钮的效果都实现了,有兴趣的小伙伴可以自己试一试哦。
- Gerrit上分支操作记录(创建分支、删除分支)
- flash 显示 qq客服状态
- android获得ImageView图片的等级
- SqlServer:此数据库处于单用户模式,导致数据库无法删除的处理
- jQuery中排除指定元素,同时选择剩下的所有元素
- windows客户机连接gerrit的一个报错处理
- 装箱与值类型虽然很容易理解,但是在实际使用中,并不总是能100%用对
- Jexus 配置ssl
- 局部打印插件 jquery.PrintArea.js
- FluorineFx应用中“页面长时间不动”导致无法连接的解决办法
- Mysql主从同步(1)-主从/主主环境部署梳理
- mysql主从同步(3)-percona-toolkit工具(数据一致性监测、延迟监控)使用梳理
- 网站压力测试软件WebBench以及压测Jexus
- Gershon Dublon & Nan Zhao:用传感器网络感知世界
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Linux 中的存储结构与磁盘划分
- Linux 中用户与权限管理
- Netty入门教程——认识Netty
- 14.VBA处理xml文件
- 一文带你理解Spring Cloud高并发微服务架构核心理念的五脏六腑
- Ubuntu设置定时任务——每10秒钟执行一次命令(修改文件权限)
- 多线程爬虫入门及问题解决(爬取表情包)
- 10.带人机对战的五子棋程序
- Spring Boot、 Spring Cloud 、OAuth2 的RBAC 权限管理系统分享
- 完美解决个人微信音频amr文件与mp3格式互转
- 【学不动了系列】之 Deno 入门 什么是Deno安装DenoDeno运行时(Runtime)Deno标准库第三方模块
- SAUI-瀑布流改版(grid)
- 深入分析 Spring 基于注解的 AOP 实现原理
- 一连问了好几个大佬,竟然都不知道Redis为什么默认16个数据库?
- 03 Spring Boot 整合Druid