这是一个十分简单的图书管理系统软件,功能也很简单。
界面整齐,方便使用。
为了使软件美观,选择了很多图片,经过不断地筛选,才最后确定下来。
关键技术主要是数据窗口的应用,数据窗是powerbuilder的一大特色,在本次编程中运用了大量的数据窗口,数据窗口是数据库和应用程序之间的桥梁,例如本程序中的功能“借阅”就使用了数据窗口“borrow”,通过数据窗口“borrow”与数据库中的表“student”和“bookinfo”相连,在运行中,点击“借阅”按钮时,界面上就显示出借阅者信息和所要借书的信息。
还有表单的运用,使用表单能够使界面简洁明了,让人能清楚的掌握软件的整体功能。
2025/8/12 5:39:41 1.85MB pb做的图书管理系统
1
第2章 QQ企业通   2.1 设计思路 28  2.2 关键技术 28  2.2.1 INI文件的应用 28  2.2.2 线程的应用 30  2.2.3 在Socket中发送大容量的消息 30  2.2.4 将流序列化或反序列化为对象 31  2.2.5 用InnerList列表记录信息 31  2.3 设计过程 32  2.3.1 类库的设计 33  2.3.2 客户端注册模块设计 40  2.3.3 客户端登录模块设计 42  2.3.4 客户端QQ模块设计 43  2.3.5 客户端消息发送模块设计 48  2.3.6 服务器端控制台模块设计 52第3章 SQL数据表提取器模块   3.1 概述 56  3.2 关键技术 56  3.2.1 如何备份数据库 56  3.2.2 如何还原数据库 57  3.2.3 如何附加数据库 58  3.2.4 如何分离数据库 59  3.2.5 设置数据库模式 59  3.3 设计过程 61  3.3.1 主窗体 61  3.3.2 获取服务器名称 62  3.3.3 获取所有数据库 63  3.3.4 获取所有数据表 64  3.3.5 备份数据库 66  3.3.6 还原数据库 67  3.3.7 附加数据库 68  3.3.8 分离数据库 70  3.3.9 导出表结构 71  3.3.10 导出数据 74第4章 万能搜索模块   4.1 设计思路 80  4.2 关键技术 80  4.2.1 如何制作一个接口程序 80  4.2.2 实现接口程序的信息互传 80  4.2.3 如何将接口程序加载到其他程序中 82  4.2.4 怎样操作RichtextBox控件的选择文本 82  4.2.5 如何获取数据表中字段的描述信息 83  4.3 设计过程 83  4.3.1 获取数据表中字段的中文信息 84  4.3.2 添加数据表的查询条件 86  4.3.3 向SQL语句中添加括号 89  4.3.4 查询生成后的SQL语句 90  4.3.5 主程序获得接口信息 92第5章 万能打印模块   5.1 设计思路 94  5.2 关键技术 94  5.2.1 打印设置(PrintDocument类) 94  5.2.2 打印预览对话框(PrintPreviewDialog) 95  5.2.3 打印对话框(PrintDialog) 96  5.2.4 获取指定颜色值和字体样式 97  5.2.5 DataGridView控件的相关应用 97  5.3 设计过程 98  5.3.1 打印信息的设置 98  5.3.2 表格样式的设置 100  5.3.3 打印类的设置 101  5.3.4 打印数据信息 108第6章 决策分析模块   6.1 设计思路 112  6.2 关键技术 112  6.2.1 游标的基本操作 112  6.2.2 存储过程的基本操作 115  6.2.3 透视表的基本概念 117  6.2.4 统计表的基本操作 117  6.2.5 单击显示右键菜单 118  6.3 设计过程 118  6.3.1 主窗体的初始化 119  6.3.2 透视表的筛选 127  6.3.3 透视表的设计 130  6.3.4 统计表的设计 132第7章 自定义图表控件   7.1 设计思路 136  7.2 关键技术 137  7.2.1 控件的生成 137  7.2.2 如何在项目中添加控件 137  7.2.3 在“属性”对话框中添加属性 137  7.2.4 用GDI+绘制图形 139  7.2.5 如何在控件上绘制图形 143  7.2.6 获取扇形外弧中心点的位置 143  7.3 设计过程 144  7.3.1 向自定义控件中添加属性 144  7.3.2 获取绘制图表的初始值数据 149  7.3.3 绘制标签框 153  7.3.4 绘制图表中的表格 157  7.3.5 绘制条形图 163  7.3.6 绘制面形图 170  7.3.7 绘制饼形图 174第8章 电子邮件收发模块   8.1 概述 180  8.2 关键技术 180  8.2.1 Base64编码格式 180  8.2.2 SMTP服务 181  8.2.3 POP3协议 184  8.2.4 使用Jmail组件接收
2025/8/4 21:47:24 10.15MB C# winform 典型系统开发模板 开发模块
1
基于SIFT特征的全景图像拼接(Qt)主要分为以下几个步骤:(1)读入两张图片并分别提取SIFT特征(2)利用k-dtree和BBF算法进行特征匹配查找(3)利用RANSAC算法筛选匹配点并计算变换矩阵(3)图像融合运行前请自己在pro文件中配置OpenCV的头文件和lib文件目录详情查看博客:http://blog.csdn.net/masikkk/article/details/9246493
1
一.功能简介1.实现一个图书管理系统。
图书信息存放到一个数据库中。
图书包含信息:图书号、图书名、作者、价格、备注字段。
2.系统实现如下的基本管理功能:(1)用户分为两类:系统管理员,一般用户。
(2)提供用户注册和用户登录验证功能;
其中登录用户的信息有:登录用户名,登录密码等。
(3)管理员可以实现对注册用户的管理(删除),并实现对图书的创建、查询、修改和删除等有关的操作。
(4)一般用户,只能查询图书,并进行借书、还书操作,每个用户最多借阅8本,即当目前借书已经是8本,则不能再借书了,只有还书后,才可以再借阅。
二.涉及技术Struts2框架、MySQL数据库、C3P0数据池、Jsp、HTML、CSS、JavaScript等技术。
三.设计思路1.基于Struts2框架进行编程设计,连接MySQL数据库实现数据的增删查改,应用Jsp、HTML、CSS、JavaScript对访问页面进行编写和美化。
2.分别创建book表和user表,用以存放图书信息和用户数据。
其中user表中,设有flag以区分管理员和普通用户。
3.分别创建Book类和User类,与数据表相对应。
每本书和每个用户都有唯一的id与之对应。
4.创建C3P0属性文件和数据库连接工具类。
5.设计数据库操作类:UserDao类和BookDao类。
UserDao用于实现所有对user表的操作,BookDao用于实现所有对book表的操作。
6.创建分别对应UserDao类和BookDao类的Action:UserAction和BookAction。
采用基于注解的方式进行Action配置。
7.用户账号分为管理员账号和普通用户账号,注册时加以区分,登录时即可自动判断进入对应的操作主页面。
8.管理员可实现对用户的查询显示,模糊查询,删除,批量删除,全选和取消全选等功能;
可实现对图书的查询显示,模糊查询,添加,删除,批量删除,全选和取消全选等功能。
9.普通用户可实现借书和还书功能,借书功能通过对book表的查询,将未借出的图书按照id顺序排列显示,点击表格后方的“借阅”按钮,进行确认借阅,将book表中本书的borrowperson列的值改为本用户账号。
对于借阅成功的图书可以在“当前借阅”中进行查看。
还书功能通过在“当前借阅”中点击“还书”按钮,进行确认还书,将book表中本书的borrowperson列的值改为“空”,本书信息将可以在“借书”界面查看。
四.存在的问题1.原本希望能为每一个用户创建一个对应的以其账号命名的数据表,用以存放用户所借图书信息,但创建表的SQL语句无法在java代码中执行,所以只好在book表中添加一列borrowperson,用来存放借阅本书的用户账号,这样查询用户当前借阅记录时,以“whereborrowperson=‘account’”为条件对book表进行查询即可。
但是每个用户要当前查询借阅记录时都需要对整个book表进行遍历,效率太低。
2.模糊查询时,因同时需要进行where筛选,SQL语句无法执行,只好分开查询,先进行模糊查询,查询结果存放到list表中,再通过遍历list表进行判断是否符合where的条件,若符合,则存入另一个list表中。
这种方法虽然实现了查询,但效率太低,代码过于繁重。
五.改进预想这些本不应该是预想,原本希望在本次作业中实现的,但时间不够充分,只能作为下一步的改建预想。
1.希望实现登录时验证码验证登录;
2.希望实现查询时,查询结果分页浏览;
3.进一步优化Action之间的传值方法;
4.页面进一步优化、美化;
5.实现用户借书还书时间记录,和借阅时长限制。
2025/7/20 9:38:38 13.98MB Struts2
1
通过时间空间datetimepicker中的年月日进行筛选,比对数据库查询出数据,只是按年月日查询,不牵扯到时分秒
2025/7/16 18:06:26 2KB 按时间查询
1
《构建Wireshark风格的网络抓包与分析工具——基于vc++6.0及WinPCAP库》网络抓包与分析是网络安全、系统优化、故障排查等领域的重要技术手段,而Wireshark作为业界广泛使用的开源工具,为用户提供了一种强大且直观的方式来查看网络通信的细节。
本文将介绍如何使用vc++6.0编程环境,结合WinPCAP库,开发一个类似Wireshark的网络数据包捕获与分析工具。
理解WinPCAP库是关键。
WinPCAP(WindowsPacketCapture)是MicrosoftWindows平台上的一个开源网络数据包捕获和网络监视系统,它允许应用程序访问网络接口的底层数据传输。
通过WinPCAP,我们可以实现对网络流量的实时监控,获取原始的数据包,并进行解析和分析。
在vc++6.0环境下,我们需要进行以下步骤来构建这个工具:1.**项目设置**:创建一个新的MFC应用程序,选择“对话框”模板,因为我们的目标是创建一个带有用户界面的工具。
2.**引入WinPCAP库**:下载并安装WinPCAP开发库,然后在项目的“配置属性”中添加WinPCAP头文件和库文件的路径。
3.**初始化WinPCAP**:在程序启动时,我们需要调用`wpcap_init()`函数初始化WinPCAP库,然后通过`pcap_open_live()`函数打开一个网络接口,以便开始捕获数据包。
4.**数据包捕获**:使用`pcap_loop()`或`pcap_next()`函数持续监听网络接口,每当有新的数据包到达时,这些函数会调用预定义的回调函数,将数据包传递给我们的程序进行处理。
5.**数据包解析**:解析捕获到的数据包需要理解网络协议栈的工作原理。
TCP/IP协议族包括链路层、网络层、传输层和应用层,每层都有各自的头部结构。
例如,以太网头部、IP头部、TCP或UDP头部等。
使用WinPCAP库提供的`pcap_pkthdr`和`pcap_pktdat`结构体,我们可以获取到每个数据包的头部信息和载荷数据。
6.**显示和分析**:根据解析结果,将数据包的关键信息(如源/目的IP、端口、协议类型、时间戳等)展示在对话框的列表控件中。
更进一步,可以实现协议分析功能,如TCP流重组、HTTP请求内容查看等。
7.**过滤功能**:Wireshark的一个显著特性是强大的过滤器。
我们可以实现自定义的过滤规则,让用户能够筛选出特定类型的数据包。
这通常涉及解析头部信息并应用逻辑条件。
8.**文件导出**:为了便于后续分析,提供数据包导出功能是必要的。
可以将捕获的数据包保存为Wireshark通用的pcap格式,以便在Wireshark或其他支持该格式的工具中打开。
9.**错误处理和优化**:确保程序在遇到错误时能够适当地通知用户,并提供关闭捕获、释放资源的选项。
此外,考虑性能优化,比如限制捕获速率,防止过度占用系统资源。
通过以上步骤,我们可以构建一个基本的网络抓包与分析工具,尽管功能可能不及Wireshark全面,但对于学习网络协议、理解数据包结构以及进行简单的网络调试来说已经足够。
随着深入学习和实践,可以逐步增加更多高级特性,使工具更加实用和专业。
2025/7/12 13:32:43 4.66MB 网络数据报抓取 分析工具 Wireshark
1
资源本来也是自己从网上所得,只不过是经过一段时间筛选和测试之后的,象征性收取2币作为时间消耗的补偿吧,2017设计工具确实有好多东西都更新了,希望对做硬件设计的同学有帮助吧,虽然xilinx坑。
2025/7/10 9:36:58 2.45MB Vivado17 lic
1
整个压缩文件有源码+数据集+运行环境+训练出的模型,项目讲解可以看下载后中的ppt,数据集是kaggle提供的数据集以及自己用爬虫爬取的数据集,去除了大部分老重复的图,就是做了一定筛选,有2400+抽烟图片,并全部标注。
2025/6/24 9:53:19 960.35MB 抽烟检测yolov4
1

在VB.NET编程环境中,掌握常用函数的使用是提高开发效率的关键。
以下是从“vb.net常用函数wgzn.txt”中提取并详细解释的一些重要知识点,涵盖了数值处理、字符串操作、日期时间管理、文件处理等多个方面。
### 数学函数1. **Abs(number)**:此函数用于获取数字的绝对值。
无论输入的数字是正数还是负数,返回的都是非负数,即去除了数字的符号部分。
2. **Atn(number)**:计算数值的反正切值,返回值为弧度制下的角度,范围在 -π/2 和 π/2 之间。
3. **Cos(number)**:计算数值的余弦值。
输入值应为弧度制的角度,输出为该角度的余弦值。
4. **Exp(number)**:计算 e(自然对数的底)的指数,即 e 的 number 次幂。
这在涉及指数增长或衰减的计算中非常有用。
5. **Log(number)**:计算以 e 为底的自然对数,即 ln(number),对于处理概率和统计问题尤为重要。
6. **Sgn(number)**:返回数字的符号。
如果 number 大于零,则返回 1;
如果等于零,则返回 0;
如果小于零,则返回 -1。
### 字符串转换与处理1. **Asc(String)**:将字符串中的第一个字符转换为其对应的 ASCII 码。
这对于处理文本数据时进行编码转换非常有用。
2. **Chr(charcode)**:将一个 ASCII 码转换为相应的字符。
这是 Asc 函数的逆向操作,常用于构建或修改字符串。
3. **LCase(String)**:将所有大写字母转换为小写。
适用于标准化文本输入,便于比较和排序。
4. **UCase(String)**:将所有小写字母转换为大写。
同样用于文本标准化。
5. **StrConv(expression, conversion)**:可以执行多种字符串转换,如大小写转换、Unicode 转换等,提供更多的灵活性。
### 类型转换1. **CBool(expression)**:将表达式转换为布尔类型(Boolean)。
通常用于逻辑判断中,确保变量或表达式的类型正确。
2. **CDate(expression)**:将表达式转换为日期时间类型(Date)。
这对于处理时间序列数据至关重要。
3. **CInt(expression)**:将表达式转换为整数类型(Integer)。
在需要精确计数或索引时非常有用。
4. **CDbl(expression)**:将表达式转换为双精度浮点数(Double)。
当需要高精度数学运算时,如科学计算,此转换是必需的。
5. **CStr(expression)**:将表达式转换为字符串类型(String)。
在显示或记录数据时,通常需要将数值或其他类型的数据转换为字符串。
### 日期时间函数1. **DateAdd(dateinterval, number, datetime)**:向指定日期添加指定的时间间隔。
这对于日程安排、数据分析等领域非常有用。
2. **DateDiff(dateinterval, date1, date2)**:计算两个日期之间的差异。
可用于计算年龄、项目持续时间等。
3. **DatePart(dateinterval, date)**:从指定日期中提取特定的部分,如年份、月份、天数等。
在数据分析中,根据日期的不同组成部分进行筛选或分组很常见。
### 文件处理1. **FileDateTime(pathname)**:返回文件的创建日期和时间。
在监控文件状态或进行数据备份时很有帮助。
2. **FileLen(pathname)**:返回文件的长度(以字节为单位)。
在进行文件传输或存储空间管理时,了解文件大小是必要的。
3. **Open filename For mode As #filenumber**:用于打开文件,可以指定文件模式(如读取、写入或追加),并分配一个文件编号以便后续操作。
4. **Close filenumberlist**:关闭由 Open 打开的文件。
确保所有数据都已正确保存,并释放系统资源。
这些函数构成了VB.NET编程语言的核心工具集,熟练掌握它们将极大地增强程序员解决问题的能力。
无论是进行数学运算、字符串操作,还是管理日期时间与文件,这些函数都是不可或缺的。
在实际开发中,结合使用这些函数可以实现复杂的功能,提高代码的效率和可读性。
2025/6/15 22:15:44 6KB
1
简介:
ExtJS是一种基于JavaScript的前端开发框架,用于构建富客户端应用。
它提供了丰富的组件库,包括TreePanel和GridPanel,这两个组件在数据展示和管理中扮演着重要角色。
TreePanel是ExtJS中的一个树形控件,它允许你展示层级结构的数据。
在教程中,你可能会学到如何创建和配置TreePanel,包括加载数据、设置节点图标、处理节点的展开和折叠事件,以及添加拖放功能。
TreePanel通常用于展现文件系统、组织架构或层级关系的数据。
GridPanel则是ExtJS中的表格视图组件,它可以展示大量的数据,并提供排序、筛选、分页等功能。
在集成TreePanel和GridPanel时,可能涉及到的概念有:将TreePanel的节点与GridPanel的数据关联,实现点击树节点时动态加载或更新GridPanel的数据,以及可能的父子数据联动操作。
在实际应用中,你可能会学习到以下关键点:1. 创建TreePanel:定义树节点的数据源,配置列显示,设置树的样式和交互行为。
2. 创建GridPanel:定义Grid的数据模型,设置列配置,添加行操作和列筛选。
3. 数据绑定:通过store将TreePanel和GridPanel连接起来,使得选择树节点可以动态改变Grid的数据。
4. 事件监听:添加事件监听器来响应用户的操作,比如节点点击、数据加载等。
5. 动态加载:当用户点击TreePanel的节点时,根据节点ID或属性动态加载对应的Grid数据。
6. 用户交互:实现拖放功能,允许用户通过拖动TreePanel的节点来调整结构,或者拖放到GridPanel中进行操作。
在"我自己写的Extjs入门教程"这个压缩包中,可能包含的文件可能有HTML示例文件、JavaScript代码文件、CSS样式文件,甚至可能有图片资源。
这些文件将帮助你理解并实践教程中的每个步骤,通过阅读和修改代码,你可以深入理解ExtJS的组件用法和数据交互机制。
在学习过程中,理解ExtJS的MVC(Model-View-Controller)架构至关重要,因为TreePanel和GridPanel都是View部分,它们的数据源(Model)和控制器(Controller)是实现功能的关键。
同时,熟悉JSON格式数据的处理也是必要的,因为ExtJS通常使用JSON来传递和存储数据。
这门入门教程将带你进入ExtJS的世界,通过TreePanel和GridPanel的实践,你将掌握基本的组件使用和数据管理技巧,为构建更复杂的企业级应用打下基础。
记得在实践中不断探索和实验,理论结合实际,才能真正掌握这些知识。
2025/6/15 19:57:15 739KB
1
共 189 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡