zoukankan      html  css  js  c++  java
  • SqlParameter参数化查询

         上篇博客写了关于重构代码用到的SQLHelper类,这个类包括四种函数,根据是否含参和是否有返回值各分两种。在这里写写传参过程用到的SqlParameter

         如果我们使用如下拼接sql字符串的方式进行数据库操作存在脚本注入的危险:

     

            Dim sql As String = "insert into T_Loginlog(userID,loginDate,loginTime,computer)values('" + Enloginlog.user_userID + "','" & Enloginlog.user_loginDate & "','" & Enloginlog.user_loginTime & "','" & Enloginlog.user_computer & "')"
    

    为了防止SQL注入,我们采用参数化查询的方式。执行带参数的sql增删改语句或存储过程的函数如下:

     

     ''' <summary>
        ''' 执行带参数的sql增删改语句或存储过程
        ''' </summary>
        ''' <param name="cmdtext">增删改语句或存储过程</param>
        ''' <param name="cmdtype">命令类型文本或存储过程</param>
        ''' <param name="paras">参数数组</param>
        ''' <returns>受影响的行数</returns>
        ''' <remarks></remarks>
        Public Function ExecuteNonQueryCan(ByVal cmdtext As String, ByVal cmdtype As CommandType, ByVal paras As SqlParameter()) As Integer
            Dim conn = GetConn()
            Dim cmd As SqlCommand = New SqlCommand(cmdtext, conn)
            Dim res As Integer
            cmd.CommandType = cmdtype
            cmd.Parameters.AddRange(paras)
            Try
                res = cmd.ExecuteNonQuery()
            Catch ex As Exception
                MsgBox(ex.Message, , "数据库操作")
            Finally
                If conn.State = ConnectionState.Open Then
                    conn.Close()
                End If
            End Try
            Return res
    
        End Function

        在这里定义了cmdtext(以sql语句为例)、cmdtypeparas,在DAL层调用sqlhelper时,只需传入相应的参数即可。其中,paras参数部分构成如下:

     

     ''' <summary>
        ''' 定义一个函数在用户输入用户名密码正确并登录时将登录信息记录到T_Login正在值班教师表中
        ''' </summary>
        ''' <param name="Enlogin">T_Login表所对应的实体</param>
        ''' <returns></returns>
        ''' <remarks></remarks>
        Public Function InsertIntoTLogin(ByVal Enlogin As Entity.EnLogin) As Boolean
    
            Enlogin.user_computer = System.Environment.MachineName
            Enlogin.user_loginDate = DateString
            Enlogin.user_loginTime = TimeOfDay
    
            Dim sql As String = "insert into T_Login(userID,loginDate,loginTime,computer)values(@userID,@loginDate,@loginTime,@computer)"
            Dim paras As SqlParameter() = {New SqlParameter("@userID", Enlogin.user_userID),
                                           New SqlParameter("@loginDate", Enlogin.user_loginDate),
                                           New SqlParameter("@loginTime", Enlogin.user_loginTime),
                                           New SqlParameter("@computer", Enlogin.user_computer)}
    
            Dim sh As SQLHelper = New SQLHelper
            If sh.ExecuteNonQueryCan(sql, CommandType.Text, paras) > 0 Then
                Return True
            Else
                Return False
            End If
    
        End Function


       说到底还是封装的思想,我们将可能输入有误的地方以参数的形式固定下来,通过传参很好的解决了这个问题。

  • 相关阅读:
    面向切面编程AOP——加锁、cache、logging、trace、同步等这些较通用的操作,如果都写一个类,则每个用到这些功能的类使用多继承非常难看,AOP就是解决这个问题的,python AOP就是装饰器
    主机异常流量示例
    python代码安全扫描工具
    联邦学习
    数据库索引数据结构总结——ART树就是前缀树
    路由器安全——破解wifi密码,同时中间人攻击
    机器学习(四)--- 从gbdt到xgboost
    Visual Studio 2013新建工程导入现有代码文件夹并且保持目录结构
    腾讯发展重心不再是微信
    linux gz 解压缩
  • 原文地址:https://www.cnblogs.com/snake-hand/p/3153197.html
Copyright © 2011-2022 走看看