使用 C# 进行面向对象编程:第 9 部分

使用 OOP 的用户活动日志

应用程序背后的关键概念

在这一部分中,我们将使用之前学到的一些 OOP 概念。我们将创建一个小型应用程序。在继续之前,请阅读我的文章user-activity-log-using-C-Sharp-with-sql-server/。在本课程中,我们将再次使用以下概念重新设计同一个应用程序。它将帮助我们更清楚地理解这些概念以及如何在我们自己的应用程序中实现它们。

  1. 成员变量
  2. 只读属性
  3. 方法
  4. 目的
  5. 默认构造函数
  6. 构造函数重载

应用详情

在数据库管理系统中跟踪用户活动。特别是在客户端-服务器环境中工作时,我们需要跟踪系统 IP/系统名称、登录 ID、时间戳以及在任何数据库应用程序上执行的操作。用户编辑任何客户端记录或进行转换等。

步骤 1. 创建名为 User_Activity_Log 的表。

CREATE TABLE [dbo].[User_Activity_Log](NOT NULL,[UAL_Timestamp] [datetime] NOT NULL,[UAL_Function_Performed] [nvarchar](100) NOT NULL,[UAL_Other_Information] [nvarchar](100) NULL,[UAL_IP_Address] [nvarchar](15) NOT NULL,PRIMARY KEY CLUSTERED([UAL_User_Id] ASC,[UAL_Timestamp] ASC) WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]GO
SET ANSI_PADDING OFF

步骤 2. 创建登录表。

CREATE TABLE [dbo].Login_Client(NULL,NULL,[LON_Employee_No] [varchar](10) NULL,[LON_Login_Password] [varchar](20) NULL,NULL,NULL
) ON [PRIMARY]GO
SET ANSI_PADDING OFF

步骤 3. 现在在登录表中插入一条记录。

INSERT INTO PSH.[dbo].[Login_Client]
VALUES ('Naveed Zaman', 'naveed.zaman', '22339', 'khan@123', 'A', 'Active')

步骤 4. 启动Visual Studio并创建一个名为“UserActivityLog_OOP_Concept”的新桌面项目。


步骤 5. 首先,我们创建登录表单,这将有助于我们理解主题的基本概念。创建如图所示的表单。


步骤 6. 创建另一个名为frmActivity的表单。


步骤 7. 现在添加一些按钮。例如,在表单上添加“添加新”、“保存”、“放弃”和“注销”按钮,如下图所示。
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

步骤 8. 添加一个名为“Main”的新类。


步骤 9. 现在我们将创建函数 GetDBConnection。它是一个公共函数,因此可以从项目中的任何位置访问它。但您必须修改与您自己的设置相关的数据源设置。

例如

SQL Server 实例名称。(.\CRMIS)
SQL Server 用户名和密码。(用户 ID sa 密码。###Reno123)
初始目录 = PSH (数据库名称)
将公共静态类添加到“Main.cs”。

public static SqlConnection GetDBConnection()
{SqlConnection conn = new SqlConnection("Data Source=.\\CRMIS;Initial Catalog=PSH;User ID=sa;Password=###Reno321");return conn;
}

步骤 10. 现在我们将创建另一个类登录,它将帮助我们验证用户的授权。提供用户名和密码后。


步骤 11. 在类登录中插入以下代码。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.SqlClient;
using System.Data;namespace UserActivityLog_OOP_Concept // 命名空间,用于组织代码
{class Login // 定义一个Login类{// 静态字段,用于存储用户IDstatic string userid;// 静态字段,用于存储密码static string password;// 静态字段,用于存储IP地址static string ip;// 公有字段,用于存储员工编号public string EmpNo = string.Empty;// SqlConnection对象,用于数据库连接SqlConnection con = Main.GetDBConnection();// 默认构造函数public Login() {}// 带参数的构造函数public Login(string _userid, string _password, string _ip) {// 初始化userid字段userid = _userid;// 初始化password字段password = _password;// 初始化ip字段ip = _ip;}// 属性,用于获取用户IDpublic string getidinfo {get {return userid;}}// 属性,用于获取密码public string getpassinfo {get {return password;}}// 属性,用于获取IP地址public string getipinfo {get {return ip;}}// 验证方法,用于验证用户凭证public string Validation() {try {// 创建DataTable对象,用于存储查询结果DataTable consultanttable = new DataTable();// 定义SQL查询语句string SQL = @"SELECT LON_Employee_No FROM Login_Client where LON_Login_Name = '" + userid + "' AND LON_Login_Password = '" + password + "'";// 创建SqlDataAdapter对象,用于执行查询并填充DataTableSqlDataAdapter Consultantdataadapter = new SqlDataAdapter(SQL, con);// 填充DataTableConsultantdataadapter.Fill(consultanttable);// 遍历查询结果foreach(DataRow myrow in consultanttable.Rows) {// 获取员工编号EmpNo = (myrow[0].ToString());}} catch (InvalidCastException e) {// 捕获并重新抛出异常throw (e);}// 返回员工编号return EmpNo;}}
}

请仔细检查代码。


我们创建了类 login,并在该类中定义了四个成员变量,其中三个是静态的,一个是公共的。我们已经在之前的文章中讨论过访问修饰符。之后,我们创建了在步骤 6 中定义的类 Main 的对象图标。它将帮助我们在 C# 和 SQL Server 之间建立连接。

之后我们定义了一个Login类的默认构造函数,并用两个参数重载了该构造函数。

理解重载构造函数的重要性非常重要。每当我们用两个参数(用户 ID 和密码)创建类的对象时,它都会被初始化。我们还定义了一个默认构造函数,当我们需要一个没有参数的类对象时,它将为我们提供帮助。


此外,我们定义了类登录的只读属性,这将有助于我们读取成员变量。


在本次课程中,我们定义了一个类登录的方法验证,它将帮助我们验证登录信息并返回 EmpNo。

步骤 12. 请在UserActivityLog类中插入以下代码。

区块A

  • 我们定义了两个成员变量。
  • 我们定义了 User_Activity_Log 类的构造函数,它有两个参数,用于初始化该类的成员变量。

B座

  • 方法任务将用于将数据插入数据库,因此我们需要在主类上使用图标名称创建对象。
  • 使用插入语句,我们可以将新行插入数据库,该数据库将获取参数操作,可以是“登录”,“添加新”,“保存”等等。

步骤 13. 请在表格中插入以下代码。

区块A

  • 我们已经初始化了表单的位置。
  • 字符串变量主机通过名称查找主机系统。
  • 获取与主机关联的 IP 地址列表。
  • 将 IP 地址分配给 CIP。
  • lblCP.文本将 IP 地址分配给将显示 IP 信息的标签。

B座

关闭登录窗口。

C 座

检查文本框是否不为空。

D 座

  • 创建对象 LG,它将使用三个参数激活类登录的构造函数。
  • 使用对象 LG 调用方法验证。
  • 使用“LG.EmpNo”公共变量我们可以正确检查用户和密码。
  • 如果信息不正确,则显示消息框。
  • 如果信息正确,那么我们将创建 UserActivityLog 类的对象“alog”;它调用具有四个参数的构造函数。
  • 使用“log”对象,我们调用将数据插入数据库的方法任务。
  • FrmActivity创建表单的对象。
  • 使用对象名称加载表单依然存在。

步骤 14. 将以下代码插入FrmActivity表单。


区块A

  • 我们已经初始化了表单的位置。
  • 我们为 UserActivityLog 类创建对象“alog”,它将使用三个参数初始化 UserActivityLog 类的成员变量,参数的值是登录类的属性。
  • 下一步是使用 UserActivityLog 类的方法“task”及其参数“添加新记录”。
    B座
  • 我们已经初始化了表单的位置。
  • 我们为 UserActivityLog 类创建一个对象“alog”,它将使用三个参数初始化 UserActivityLog 类的成员变量,参数的值是登录类的属性。
  • 下一步是使用 UserActivityLog 类的方法“task”和参数“保存记录”。
    区块 C、D 和 E 也同样如此。

步骤 15 现在按 F5。您将看到登录屏幕;只需输入即可。

  • 用户名: Naveed.zaman
  • 用户名: khan@123


单击登录按钮。


现在按“添加新”按钮、“保存”按钮、“放弃”按钮,然后按“登录”按钮。

步骤 16 现在打开SQL Server表;您将得到如下结果。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/351661.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LabVIEW进行负载测试

本文介绍了如何使用LabVIEW进行负载测试,通过一个具体案例详细讲解了测试系统的组成、工作原理和实现方法。系统采用先进的硬件和软件架构,结合LabVIEW的强大功能,成功实现了对设备的高效负载测试,确保了系统的可靠性和性能。 项…

拥抱开源,构建未来:王嘉树与 TDengine 的开源之旅

在当代的技术浪潮中,开源文化不仅催生了无数创新技术,也为广大技术爱好者提供了一个展示才华、相互学习的平台。我们今天采访到的这位北京邮电大学电子工程学院的研究生,就是在这样的背景下,通过开源活动不断探索、学习并实现自我…

2024年汉字小达人活动还有4个多月开赛:来做18道历年选择题备考吧

结合最近几年的活动安排,预计2024年第11届汉字小达人比赛还有4个多月就启动,那么孩子们如何利用这段时间有条不紊地准备汉字小达人比赛呢? 我的建议是充分利用即将到来的暑假:①把小学1-5年级的语文课本上的知识点熟悉&#xff0…

Docker 安装 MySQL5.7 和 MySQL8

文章目录 安装 MySQL5.7拉取镜像前期准备启动容器 安装MySQL8.0拉取镜像查看镜像前期准备启动容器 安装 MySQL5.7 拉取镜像 docker pull mysql:5.7拉下来镜像后 执行 docker images 此时我们已经有这个镜像了。 前期准备 在根目录下创建 app , 在 app 目录下创建…

蚂蚁SEO的蜘蛛对网页收录有帮助吗 ?

网页蜘蛛对网站收录有着至关重要的帮助。在深入探讨这一话题之前,我们首先需要了解网页蜘蛛的工作原理及其在互联网生态系统中的角色。 网页蜘蛛,也被称为网络爬虫或网络机器人,是搜索引擎的核心组成部分。它们按照特定的算法和规则&#xff…

力扣231. 2 的幂(位运算)

Problem: 231. 2 的幂 文章目录 题目描述思路及解法复杂度Code 题目描述 思路及解法 1.若为0和负数则直接返回false; 2.利用一个标志数mask令其为一,不断的算术左移同时和n做与(&)运算,统计n中二进制位为1的个数&a…

Java | Leetcode Java题解之第155题最小栈

题目&#xff1a; 题解&#xff1a; class MinStack {Deque<Integer> xStack;Deque<Integer> minStack;public MinStack() {xStack new LinkedList<Integer>();minStack new LinkedList<Integer>();minStack.push(Integer.MAX_VALUE);}public void …

windows环境下配置git环境变量

路由当前目录 vim 打开 .bash_profile PATH$PATH:/d/phpstudy_pro/Extensions/php/php7.4.3nts PATH$PATH:/d/phpstudy_pro/Extensions/php8/php8.2.9nts PATH$PATH:/d/phpstudy_pro/Extensions/composer2.5.8 …

搭建一个简单的深度神经网络

目录 一、引入所需要的库 二、制作数据集 三、搭建神经网络 四、训练网络 五、测试网络 本博客实验环境为jupyter 一、引入所需要的库 torch库是核心&#xff0c;其中torch.nn 提供了搭建网络所需的所有组件&#xff0c;nn即神经网络。matplotlib类似与matlab&#xff0…

【react小项目】bmi-calculator

bmi-calculator 目录 bmi-calculator初始化项目01大致布局01代码 02完善样式02代码 03输入信息模块03代码 04 使用图表04代码 05详细记录信息渲染05代码 06 让数据变成响应式的06-1输入框的数据处理06-2图表&#xff0c;和记录信息的区域数据处理 07 删除功能&#xff0c;撤销功…

弗洛伊德算法——C语言

弗洛伊德算法&#xff0c;是一种用于解决所有顶点对之间最短路径问题的经典算法&#xff0c;该算法通过动态规划的方法计算出从每个顶点到其他所有顶点的最短路径。 弗洛伊德算法的基本思想是逐步考虑每一个顶点作为中间点&#xff0c;更新所有顶点对之间的最短路径。它通过以…

mySql的事务(操作一下)

目录 1. 简介2. 事务操作3. 四大特性4. 并发事务问题5. 脏读6. 不可重复读7. 幻读事务隔离级别参考链接 1. 简介 事务是一组操作的集合&#xff0c;它是一个不可分割的工作单位&#xff0c;事务会把所有的操作作为一个整体一起向系统提交或撤销操作请求&#xff0c;即这些操作…

html是什么?http是什么?

html Html是什么&#xff1f;http是什么&#xff1f; Html 超文本标记语言&#xff1b;负责网页的架构&#xff1b; http(&#xff08;HyperText Transfer Protocol&#xff09;超文本传输协议&#xff1b; https&#xff08;全称&#xff1a;Hypertext Transfer Protocol …

VMware 桥接网络突然无法上网

VMware 桥接网络突然无法上网 0. 问题1. 解决方法 0. 问题 昨天&#xff0c;VMware 桥接网络正常使用&#xff0c;今天突然无法上网。 1. 解决方法 打开VMware的虚拟网络编辑器&#xff0c;将桥接模式的网络从“自动”改成你要使用的网卡&#xff0c;问题解决。 完成&#…

Numpy

文章目录 一、数据维度的概念1.1常见的多维数据1.2numpy的维度、形状、轴1.2.1维度1.2.2形状1.2.3轴 1.3reshape()函数1.4numpy中行、列向量的表示1.5数组的迭代1.6添加/删除元素1.6.1append()1.6.2insert()1.6.3delete() 二、Ndarray对象2.1简介2.1.1常用属性2.1.2.ndarray对象…

Python | Leetcode Python题解之第160题相交链表

题目&#xff1a; 题解&#xff1a; class Solution:def getIntersectionNode(self, headA: ListNode, headB: ListNode) -> ListNode:A, B headA, headBwhile A ! B:A A.next if A else headBB B.next if B else headAreturn A

Office办公软件如何下载安装?Office 2021最佳的办公软件安装包资源分享!

Office软件这种文档格式的普及&#xff0c;得益于其高度的兼容性和通用性&#xff0c;使得用户能够轻松地在不同的电脑和平台上打开和编辑文件。 Office软件文档格式的通用性&#xff0c;意味着无论是Windows、macOS还是Linux等操作系统&#xff0c;用户都能无障碍地打开和浏览…

【源码】16国语言交易所源码/币币交易+期权交易+秒合约交易+永续合约+交割合约+新币申购+投资理财/手机端uniapp纯源码+PC纯源码+后端PHP

测试环境&#xff1a;Linux系统CentOS7.6、宝塔面板、Nginx、PHP7.3、MySQL5.6&#xff0c;根目录public&#xff0c;伪静态laravel5&#xff0c;开启ssl证书 语言&#xff1a;16种&#xff0c;看图 这套带前端uniapp纯源码&#xff0c;手机端和pc端都有纯源码&#xff0c;后…

经典电源电路基础(变压-整流-滤波-稳压)

1.电源电路的功能和组成 电子电路中的电源一般是低压直流电&#xff0c;先把220v交流电变换成低压直流电&#xff0c;再用整流电路变成脉动的直流电&#xff0c;最后用滤波电路滤除掉脉动直流中的交流成分后才能得到直流电。有的电子设备对电源的质量要求很高&#xff0c;所以…

用Copilot画漫画,Luma AI生成视频:解锁创意新玩法

近年来&#xff0c;随着人工智能技术的不断发展&#xff0c;各种创意工具也层出不穷。今天&#xff0c;我们就来介绍一种全新的创作方式&#xff1a;使用Copilot画漫画&#xff0c;再将漫画放入Luma AI生成视频。 Copilot&#xff1a;你的AI绘画助手 Copilot是一款基于人工智…