資料庫漏洞解決辦法

來源:互聯網
上載者:User

這隻是針對一種資料庫漏洞的解決辦法

如果查詢語句是"select * from T_User where username='" + textBox1.Text + "' and password= '" + textBox2.Text + "'";//這種方法不夠安全,因為如果在密碼中輸入' or '1'='1  同樣登入成功,這就是.資料庫漏洞
     

 

OleDbConnection mycon;
OleDbCommand myCommand;
OleDbDataReader myDataReader;

 

string myConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\\Documents and Settings\\Administrator\\案頭\\new.mdb";
            mycon = new OleDbConnection(myConnectionString);
            try
            {
                mycon.Open();

                string cmdstr = "select * from T_User where username= ? and password= ?";
                myCommand = new OleDbCommand(cmdstr, mycon);
                /////////////////////////////////////////////////////////////////
                myCommand.Parameters.Clear();//清空參數
                ////////////////////////////////////////////////////////////////
                OleDbParameter pUsername = new OleDbParameter("cs1",OleDbType.Char);//設定第一個參數
                pUsername.Value = textBox1.Text;
                myCommand.Parameters.Add(pUsername);
                ///////////////////////////////////////////////////////////////
                OleDbParameter pPassword = new OleDbParameter("cs2", OleDbType.Char);//設定第二個參數
                pPassword.Value = textBox2.Text;
                myCommand.Parameters.Add(pPassword);
                /////////////////////////////////////////////////////////////
                myDataReader=myCommand.ExecuteReader();//這邊是執行資料庫操作

             if (myDataReader.HasRows)
              {
                    MessageBox.Show("登入成功");
              }
              else
              {
                    MessageBox.Show("登入失敗");
               }
            myDataReader.Close();
            mycon.Close();
            }
            catch (Exception e)
            {
                MessageBox.Show(e.ToString());
            }

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.