Bogart SysPwd.vb
Module syspwd
Public Const STR_MASK = "MyFunction" '加密用字串
Public Const INT_PWD_LENGTH = '預定義密碼長度
Public GintCheckPwd As Integer
'當傳入的密碼長度大於預定義密碼長度時
'將?生一個Message Box
'以下兩個常量是該Message Box中的具體提示資訊和標題欄中的文字
Public Const STR_PWD_ERROR = "The length of password can not be greater than 10 characters !"
Public Const STR_SYSTEM_NAME = "Bogart Report System"
Public Const STR_INVALID_USER = "Password is not valid !"
Public Const STR_CHANGE_PASSWORD_ERROR = "User ID is not valid !"
'以下的變數的定義在正式使用時去掉
'該函數的作用是將傳入的密碼字串轉換成加密的密碼字串
'傳入的字串是用戶輸入的未經過系統加密的密碼
'傳出的資料類型是字串型,?經過系統加密後的密碼
Public Function EnPwd(ByVal strIn As String) As String
Dim intCount As Integer
Dim intPwdWord() As Integer
Dim intTemp As Integer
Dim strColumn1 As String
Dim strColumn2 As String
Dim strColumn3 As String
Dim strTemp As String
Dim intDivTemp As Integer
strColumn1 = ""
strColumn2 = ""
strColumn3 = ""
intTemp =
strTemp = ""
intDivTemp =
If Len(strIn) > INT_PWD_LENGTH Then
MsgBox(STR_PWD_ERROR, , STR_SYSTEM_NAME)
EnPwd = ""
Exit Function
End If
ReDim intPwdWord(INT_PWD_LENGTH)
For intCount = To INT_PWD_LENGTH
If Len(STR_MASK) < INT_PWD_LENGTH Then
intTemp = intTemp +
If intTemp > Len(STR_MASK) Then
intTemp =
End If
intPwdWord(intCount) = Asc(Mid(STR_MASK, intTemp, ))
Else
intPwdWord(intCount) = Asc(Mid(STR_MASK, intCount, ))
End If
Next
For intCount = To Len(strIn)
intTemp = Asc(Mid(strIn, intCount, ))
intDivTemp = intDivTemp +
If intDivTemp > Then
intDivTemp =
End If
intTemp = intTemp * intDivTemp
intPwdWord(intCount) = intPwdWord(intCount) + intTemp
Next
For intCount = To INT_PWD_LENGTH
strTemp = CStr(intPwdWord(intCount))
If Len(strTemp) < Then
strTemp = StrDup( - Len(strTemp), "") & strTemp
End If
strColumn1 = strColumn1 & Mid(strTemp, , )
strColumn2 = strColumn2 & Mid(strTemp, , )
strColumn3 = strColumn3 & Mid(strTemp, , )
Next
EnPwd = strColumn1 & strColumn2 & strColumn3
End Function
'該函數的作用是將傳入的加密的密碼字串轉換成不加密的密碼字串
'傳入的字串是經過系統加密後的密碼
'傳出的資料類型是字串型,?未經過系統加密的密碼
Public Function DePwd(ByVal strIn As String) As String
Dim intCount As Integer
Dim intTemp As Integer
Dim strTemp As String
Dim strColumn1 As String
Dim strColumn2 As String
Dim strColumn3 As String
Dim intPwdWord() As Integer
Dim intDivTemp As Integer
DePwd = ""
strColumn1 = ""
strColumn2 = ""
strColumn3 = ""
intTemp =
strTemp = ""
intDivTemp =
strColumn1 = Mid(strIn, , INT_PWD_LENGTH)
strColumn2 = Mid(strIn, INT_PWD_LENGTH + , INT_PWD_LENGTH)
strColumn3 = Mid(strIn, INT_PWD_LENGTH * + , INT_PWD_LENGTH)
strTemp = ""
For intCount = To INT_PWD_LENGTH
strTemp = strTemp & Mid(strColumn1, intCount, )
strTemp = strTemp & Mid(strColumn2, intCount, )
strTemp = strTemp & Mid(strColumn3, intCount, )
Next
ReDim intPwdWord(INT_PWD_LENGTH)
For intCount = To INT_PWD_LENGTH
intPwdWord(intCount) = Val(Mid(strTemp, intCount * - , ))
If Len(STR_MASK) < INT_PWD_LENGTH Then
intTemp = intTemp +
If intTemp > Len(STR_MASK) Then
intTemp =
End If
intPwdWord(intCount) = intPwdWord(intCount) - Asc(Mid(STR_MASK, intTemp, ))
Else
intPwdWord(intCount) = intPwdWord(intCount) - Asc(Mid(STR_MASK, intCount, ))
End If
intDivTemp = intDivTemp +
If intDivTemp > Then
intDivTemp =
End If
intPwdWord(intCount) = intPwdWord(intCount) / intDivTemp
If intPwdWord(intCount) <> Then
DePwd = DePwd & Chr(intPwdWord(intCount))
End If
Next
End Function
'以下函數?檢查密碼是否有效
'傳入的第一個參數?用戶名,第二個是密碼(未加密)
'如果密碼正確,則返回True
'如果密碼不正確或該用戶不存在,則出現MsgBox後返回False
Public Function CheckPwd(ByVal strUser As String, ByVal strPassword As String) As Boolean
GintCheckPwd = GintCheckPwd +
Dim Rs As New ADODB.Recordset
Dim strSQLStmt As String
CheckPwd = False
On Error GoTo DBError
If adoConn.State <> ConnectionState.Open Then
adoConn.Open()
End If
strSQLStmt = "SELECT Password FROM " & g.gRptdev & "g_userid WHERE UserID='" & strUser & "'"
'以下的dbconn應該改寫成統一的連庫
Rs.Open(strSQLStmt, adoConn, ADODB.CursorTypeEnum.adOpenStatic, ADODB.LockTypeEnum.adLockOptimistic)
If Rs.Fields().Value <> EnPwd(strPassword.ToUpper) Then
MsgBox(STR_INVALID_USER, vbCritical, STR_SYSTEM_NAME)
'If GintCheckPwd = 3 Then
' MsgBox("您已經三次登陸失敗,系統將退出", vbExclamation, STR_SYSTEM_NAME)
'End If
Exit Function
End If
CheckPwd = True
Exit Function
DBError:
MsgBox(STR_INVALID_USER, vbExclamation, STR_SYSTEM_NAME)
End Function
'以下函數?檢查密碼是否有效
'傳入的第一個參數?用戶名,第二個是新密碼(未加密)
'如果更改成功,則返回True
'如果更改不成功(可能因?用戶不存在等原因),則出現MsgBox後返回False
Public Function ChangePwd(ByVal strUser As String, ByVal strPassword As String) As Boolean
Dim Rs As ADODB.Recordset
Dim strSQLStmt As String
ChangePwd = False
On Error GoTo DBError
adoConn.BeginTrans()
strSQLStmt = "SELECT Password FROM " & g.gRptdev & "g_userid WHERE UserID='" & strUser & "'"
'以下的dbconn應該改寫成統一的連庫
Rs = adoConn.Execute(strSQLStmt)
If Rs.EOF Then
MsgBox(STR_CHANGE_PASSWORD_ERROR, , STR_SYSTEM_NAME)
Rs.Close()
adoConn.RollbackTrans()
Exit Function
End If
Rs.Close()
strSQLStmt = "UPDATE " & g.gRptdev & "g_userid SET Password = '" & EnPwd(strPassword.ToUpper) & "' WHERE UserID='" & strUser & "'"
adoConn.Execute(strSQLStmt)
adoConn.CommitTrans()
ChangePwd = True
Exit Function
DBError:
MsgBox(STR_CHANGE_PASSWORD_ERROR, , STR_SYSTEM_NAME)
adoConn.RollbackTrans()
End Function
End Module
Bogart SysPwd.vb的更多相关文章
- Bogart BogartPublic.vb
Imports System.Data.SqlClient Imports System.Data #Region "IBogartToolbar,請勿隨便更改" Interfac ...
- Bogart gSub.vb
'--------------Job No 0900408 -------------- '--DIM PART ONE ONLINE Update Order Qty '''主要新加過程名 Refr ...
- Bogart gData.vb
Imports System Imports System.Data Imports System.Data.OleDb Imports Microsoft.VisualBasic Imports S ...
- Bogart BogartAutoCode.vb
Imports System.Data.SqlClient Imports System.Data Public Class BogartAutoCodeDataBase Private Conn A ...
- Bogart gFunction.vb
Module gFunction '其它不是常用的方法及函數 #Region " 將指定的數據格式轉換為英文格式" Public Function EnglishFormat(By ...
- Bogart gGrid.vb
Namespace BogartMis.Cls Public Class gGrid '設定表格控的列標題的別名 '說明:strItem字符串的格式為"01,02,03,04,05" ...
- [转载]C#中MessageBox.Show用法以及VB.NET中MsgBox用法
一.C#中MessageBox.Show用法 MessageBox.Show (String) 显示具有指定文本的消息框. 由 .NET Compact Framework 支持. MessageBo ...
- VB.NET设置控件和窗体的显示级别
前言:在用VB.NET开发射频检测系统ADS时,当激活已存在的目标MDI子窗体时,被其他子窗体遮住了,导致目标MDI子窗体不能显示. 这个问题怎么解决呢?网上看到一篇帖子VB.NET设置控件和窗体的显 ...
- 用VB脚本批到导入字段到PowerDesigner
在PowerDesigner使用脚本批量导入excel中记录的表结构信息,由于需要通过powerdesigner逆向工程创建一些sybase IQ的表,由于是接口数据,只有excel表,手动导入太耗时 ...
随机推荐
- 怎样取消老毛桃软件赞助商---只需在输入框中输入老毛桃官网网址“laomaotao.org”
来源:www.laomaotao.org 时间:2015-01-29 在众多网友和赞助商的支持下,迄今为止,老毛桃u盘启动盘制作工具已经推出了多个版本.如果有用户希望取消显示老毛桃软件中的赞助商,那不 ...
- smarty学习——变量
变量的处理对于模板来说是比较重要的. Smarty有几种不同类型的变量. 变量 的类型取决于它的前缀是什么符号(或者被什么符号包围) Smarty的变量可以直接被输出或者作为函数属性和修饰符(modi ...
- [unity3d]角色控制器组件相互间不碰撞
RPG游戏会有这种需求. 队友之间,玩家之间.玩家与怪物之间,都有可能须要不能碰撞.怎样实现?这个问题困恼了一段时间,昨天在网上看到解答的方法: 这里举例玩家和怪物之间: 1,填加2个不同的层级mon ...
- es6 中,大多数开发者和 babel 之类的工具默认添加 use strict 到 JS 文件的头部,确保采用严格模式
严格模式(use strict) 有助于防止问题用法,并且它也有助于安全使用 JavaScript. 在 ES5 中, 严格模式是可选项,但是在 ES6 中,许多特性要求必须使用严格模式. 因此大多数 ...
- mysql explicit_defaults_for_timestamp参数
在mysql中:- timestamp列如果没有显式定义为null,默认会被设置为not null属性.(其它的数据类型如果没有显式定义为not null,默认是可以为null的).设置timesta ...
- bzoj 3611(洛谷 4103) [Heoi2014]大工程——虚树
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3611 https://www.luogu.org/problemnew/show/P4103 ...
- RK3288 wifi模块打开或关闭5G信号
CPU:RK3288 系统:Android 5.1 如果硬件使用的wifi模块支持5G,则系统设置中打开wifi,除了会搜索到普通的2.4G信号,还会搜索到xxx_5G信号. 如果路由器开了5G信号, ...
- valgrind的使用--检测内存
valgrind主要检测内存的使用情况,检测有否内存泄露等. 比如:test_va2.cpp #include<iostream> using namespace std; int mai ...
- nginx信号量
nginx信号说明相关说明 信号名称 作用 TERM,INT 快速关闭 QUIT 从容关闭 HUP 重新加载配置,用新的配置开始新的工作进程,从容关闭旧的工作进程 USR1 重新打开日志文件 USR2 ...
- C/C++基础----string, vector, array
1 using声明 方便使用命名空间中的成员,不用每次xxx::yyy 头文件不应该包含using声明(不经意间包含了一些名字) 2 string 表3.1:初始化string对象的方式 string ...