【C#】参数化处理sql漏洞

    ##**参数化处理sql**
        Console.WriteLine("输入用户名");
        string uid = Console.ReadLine();
        Console.WriteLine("输入密码");
        string pwd = Console.ReadLine();
        //登陆
        string connStr = @"server=.;dataBase=scott;uid=sa;pwd=123";
        string sql = "select count(1) from Logintbl "
            +" where uid=@uid and pwd=@pwd";
        SqlParameter pUid = new SqlParameter("@uid",uid);
        SqlParameter pPwd = new SqlParameter("@pwd",pwd);
        int count;
        using (SqlConnection conn = new SqlConnection(connStr))
        {
            using (SqlCommand cmd = new SqlCommand(sql, conn))
            {
                cmd.Parameters.Add(pUid);
                cmd.Parameters.Add(pPwd);
                conn.Open();
                count = (int)cmd.ExecuteScalar();
            }
        }
        Console.WriteLine(count);
        Console.ReadKey();

//可避免用1’ or ‘1’=‘1 注入攻击
###很古老的处理方式
用pwd.Replace(" ’ “,” ’ ’ ");
这种方式是只是处理单引号‘,但是后面加上1’\n delete table的话也不行,不严谨
所以还是建议用参数化处理sql拼接问题

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值