三层已经学了一些时间了,開始认为自己能够用C#敲代码了,就用C#写了一个实现登陆的,真正再用在机房中。还是认为非常吃力的,所以。决定用vb.net敲了。以下是我用vb.net实现的登陆。能够给大家做一些參考。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcWl1bXV4aWEwOTIx/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

这是构架的三层

数据库中的表T_User_DAL:UserI。Level,Password,Head,computer

首先看一下

Entity层:

Public Class UserInfoEntity
#Region "定义变量"
Private _userID As String
Private _level As String
Private _Head As String
Private _password As String
#End Region
Public Property UserID() As String '将T_User_DAL表中的每个实体都传上去,实体是依据表来建的,不是功能
Get
Return _userID
End Get
Set(value As String)
_userID = value
End Set
End Property
Public Property Level() As String
Get
Return _level
End Get
Set(ByVal value As String)
_level = value
End Set
End Property
Public Property Head() As String
Get
Return _Head
End Get
Set(value As String)
_Head = value
End Set
End Property
Public Property Password() As String
Get
Return _password
End Get
Set(value As String)
_password = value
End Set
End Property End Class

DAL层:

为了可以减少耦合一定要将连接字符串拿出来。不要每个DAL中都写一边。

Imports System.Data
Imports System.Data.SqlClient
Public Class SqlUtil
Public Shared Function connstring() As String
'connstring = "Server=192.168.24.183;Database=ReconsitutionCharge_sys;User ID=sa;Password=123456" ‘会出现无法识别userid的错误
connstring = "Server=mx; Database=ReconsitutionCharge_sys; User ID=sa; Password=123456" '连接SQL的字符串
End Function End Class

T_User_dal表DAL层代码:

Imports System.Data.SqlClient
Imports System.Data
Public Class UserDAL
Public Function SelectUser(ByVal user As Entity.UserInfoEntity) As Entity.UserInfoEntity
Dim conn As New SqlConnection '定义连接打开数据库
Dim cmd As New SqlCommand '定义数据库命令
conn = New SqlConnection(SqlUtil.connstring()) '实例化SQLUntil中返回的字符串
cmd.Connection = conn cmd.CommandText = "Select * From T_User_DAL Where UserID=@UserID and Password=@Password" '存储过程 cmd.Parameters.Add(New SqlParameter("@UserID", user.UserID)) '赋值,传參
cmd.Parameters.Add(New SqlParameter("@Password", user.Password))
cmd.CommandType = CommandType.Text 'CommandText 属性设置为存储过程的名称。当调用 Execute 方法之中的一个时,该命令将运行此存储过程
conn.Open() '打开连接 Dim reader As SqlClient.SqlDataReader '读取数据库中的表
reader = cmd.ExecuteReader() Dim users As New Entity.UserInfoEntity '实例化实体 While (reader.Read())
'If users Is Nothing Then
' user = New Entity.UserInfoEntity
'End If
users.UserID = reader.GetString(reader.GetOrdinal("UserID"))
users.Password = reader.GetString(reader.GetOrdinal("Password"))
End While
conn.Close()
Return users
End Function
End Class

BLL层:

Public Class LoginBLL
Function UserLogin(ByVal user As Entity.UserInfoEntity) As Entity.UserInfoEntity
Dim uDAL As New DAL.UserDAL '实例化了DAL中的UserDAL
Dim users As New Entity.UserInfoEntity '实例化了Entity层信息表 users = uDAL.SelectUser(user) 'selectUser是返回一个Entity类的,给它赋值user
Return users '返回users实体
End Function End Class

UI层:

界面设计:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcWl1bXV4aWEwOTIx/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

   Private Sub btnLogin_Click(sender As Object, e As EventArgs) Handles btnLogin.Click
Dim mgr As New BLL.LoginBLL '实例业务层
Dim user As New Entity.UserInfoEntity '实例实体
Dim users As Entity.UserInfoEntity '接收实体,用于接收UserLogin()返回的数据类型,假设没有New就不是实例化 user.UserID = txtUserID.Text.Trim() '给实体层传入值
user.Password = TxtPassword.Text.Trim()
If txtUserID.Text = "" Then '推断输入是否正确
MsgBox("username不能为空!")
Return
End If If TxtPassword.Text = "" Then
MsgBox("password不能为空!")
Return
End If Try 'users接收实体
users = mgr.UserLogin(user) If (users.UserID Is Nothing And users.Password Is Nothing) Then '假设users不为空。则登陆成功!
MsgBox("登陆失败,username和password不匹配")
Return
Else
MsgBox("登陆成功。登陆用户:" + user.UserID)
End If
Catch ex As Exception
MsgBox(ex.Message())
End Try
End Sub
End Class

VB.NET版+三层实现登陆的更多相关文章

  1. 三层登录——VB.NET版

    前言 由于下面的机房收费系统重构自己要用VB.NET进行重构,所以在敲三层登录的时候,实践了一份C#版三层登录,接着就是VB.NET版的三层登录.话说还有七层登录,一下子感觉三层又矮小了.万丈高楼平地 ...

  2. 三层——vb.net版

    经过不懈的努力,我的vb.net 版的三层登陆终于实现了.下面将我的成果向大家展示一下. 原则          vb.net的三层登陆跟C#的三层登陆的思想是一样的都是将系统分层--U层只负责与用户 ...

  3. VB.NET版机房收费系统---导出Excel表格

    datagridview,翻译成中文的意思是数据表格显示,使用DataGridView控件,能够显示和编辑来自不同类型的数据源的表格,将数据绑定到DataGridView控件很easy和直观,大多数情 ...

  4. VB.NET版机房收费系统---异常处理

    异常处理,英文名为Exceptional Handling, 那时年少,还记得那年一起学习过的VB6.0的时候,常常使用ONError的错误语句.与传统VB6.0中的OnError语句相比.NET平台 ...

  5. [转]C#三层架构登陆实例

    很早之前,就听说过三层结构了.当时只知道 三层结构 是把 系统的 界面  跟 数据库操作等不相关的程序分别开来.原来这么简单的实现,确实传说中的 三层结构啊. 首先,先来看一下是哪三层.表示层(UI, ...

  6. VB.net版机房收费系统——结账功能实现(调错与优化)

    调错部分 上一篇博客<VB.net版机房收费系统--结账功能实现(代码部分>说的是结账功能的实现,亮出了代码.是在为这篇博客做铺垫.尽管结账功能代码是借鉴的巨人的博客.可是自己比着葫芦画瓢 ...

  7. 三层架构实例 VB.NET版

    三层实例 首先发现感慨,对于三成这块,用到都是一些面向对象的特征,尤其是对象的实例化.如果你不是很注意的话,那么,你就会一头雾水,就像我一样,慢慢的雾里看花,最后也是走出来的,不过用的事件是相当的. ...

  8. 三层登录实例VB.NET版详解---理论加实战篇

    层,百度百科这样解释,首先-重叠起来的东西:重叠起来的东西中的一部分:层次|表层|大气层.其次-重叠:重复:层峦叠嶂|层出不穷.最后-量词,用于可以分出层次的事物,女孩儿强烈的第六感,三层中的层一定是 ...

  9. 三层登录实例VB.NET版具体解释---理论加实战篇

    层,百度百科这样解释,首先-重叠起来的东西:重叠起来的东西中的一部分:层次|表层|大气层.其次-重叠.反复:层峦叠嶂|层出不穷.最后-量词,用于能够分出层次的事物.女孩儿强烈的第六感,三层中的层一定是 ...

随机推荐

  1. ./adb: error while loading shared libraries: libncurses.so.5:

    from://http://stackoverflow.com/questions/10005907/eclipse-android-plugin-libncurses-so-5 sudo apt-g ...

  2. 3种LVS/Nginx/HAProxy负载均衡器的对比分析

    现在网站发展的趋势对网络负载均衡的使用是随着网站规模的提升根据不同的阶段来使用不同的技术: 一种是通过硬件来进 行进行,常见的硬件有比较昂贵的NetScaler.F5.Radware和Array等商用 ...

  3. [DEFCON全球黑客大会] CTF(Capture The Flag)

    copy : https://baike.baidu.com/item/ctf/9548546?fr=aladdin CTF(Capture The Flag)中文一般译作夺旗赛,在网络安全领域中指的 ...

  4. [转]Hadoop Hive sql语法详解

    转自 : http://blog.csdn.net/hguisu/article/details/7256833 Hive 是基于Hadoop 构建的一套数据仓库分析系统,它提供了丰富的SQL查询方式 ...

  5. 迪米特法则(Law Of Demeter)

    定义:一个对象应该对其他对象保持最少的了解. 问题由来:类与类之间的关系越密切,耦合度越大,当一个类发生改变时,对另一个类的影响也越大. 解决方案:尽量降低类与类之间的耦合. 自从我们接触编程开始,就 ...

  6. RV32I指令集

    RV32I是最基本的32位Base指令集,它支持32位寻址空间,支持字节地址访问,仅支持小端格式(little-endian,高地址高位,低地址地位),寄存器也是32位整数寄存器.RV32I指令集的目 ...

  7. win10 下 protobuf 与 qt

    编译环境: win10 x64   编译器 :mingw32  cmake 使用场景:Qt4.8.7 下载 protobuf 最新的代码:https://github.com/google/proto ...

  8. CListCtrl 之右键菜单

    在使用CListCtrl时要为它添加一个右键菜单,步骤如下: 1. 响应CListCtrl的NM_RCLICK消息. 2. 添加一个菜单资源,在菜单资源中插入要添加到菜单内容.   一般存在两种方法: ...

  9. Sum Root to Leaf Numbers leetcode java

    题目: Given a binary tree containing digits from 0-9 only, each root-to-leaf path could represent a nu ...

  10. Swift语言从天而降,是否能掀起新一轮的科技革命?

    Swift语言从天而降,是否能掀起新一轮的科技革命? Swift语言诞生到如今,才短短一个月多,Swift居然挤进TIOBE排行榜的第16位,相信这发展的速度绝不是不论什么一个语言可与之相提并论,那S ...