Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/15: Рейтинг темы: голосов - 15, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 06.09.2019
Сообщений: 21

Возвращается пустой запрос

15.07.2021, 22:54. Показов 3152. Ответов 3

Студворк — интернет-сервис помощи студентам
Есть форма авторизации, при клике по кнопке войти, должно происходить сравнение того, что введено в текст боксе и того, что имеется в базе данных.

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
private void BTN_Run_Click(object sender, EventArgs e)
        {
            string connectString = "Data Source=.\\SQLEXPRESS;Initial Catalog=CompanyDataBase; Integrated Security=True";
            SqlConnection myConnection = new SqlConnection(connectString);
 
            myConnection.Open();
 
            string query = "SELECT ЛИЧНЫЙ_КАБИНЕТ.ЛОГИН FROM [ЛИЧНЫЙ_КАБИНЕТ] WHERE ЛОГИН LIKE '" + TB_Login.Text + "'";
 
            SqlCommand command = new SqlCommand(query, myConnection);
 
          /*  command.Parameters.AddWithValue("@ULg", TB_Login.Text);
            command.Parameters.AddWithValue("@UPw", TB_Password.Text);*/
 
            var reader = command.ExecuteReader();
 
            while (reader.Read())
            {
                string RezLog = "";
                RezLog += (reader.GetString(1).ToString());
 
               /* string RezPass = "";
                RezPass += (reader.GetString(2).ToString());*/
                
                if(RezLog.Equals(TB_Login.Text)/* && RezPass.Equals(TB_Password.Text)*/)
                {
                    //Все верно
                    labelERROR.Text = "Такое есть";
                    myConnection.Close();
                }
                else
                {
                    //Что-то не так
                    labelERROR.Text = "Неверный логин или пароль";
                    myConnection.Close();
                }
            }
}
После клика по кнопке ничего не происходит. Получается, что reader пустой.

Есть еще такой вариант:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
private void BTN_Run_Click(object sender, EventArgs e)
        {
            string connectString = "Data Source=.\\SQLEXPRESS;Initial Catalog=CompanyDataBase; Integrated Security=True";
            SqlConnection myConnection = new SqlConnection(connectString);
 
            myConnection.Open();
 
            string query = "SELECT ЛИЧНЫЙ_КАБИНЕТ.ЛОГИН, ЛИЧНЫЙ_КАБИНЕТ.ПАРОЛЬ FROM [ЛИЧНЫЙ_КАБИНЕТ] WHERE ЛОГИН LIKE '" + TB_Login.Text + "' AND ПАРОЛЬ = '" + TB_Password.Text + "'";
 
            SqlCommand command = new SqlCommand(query, myConnection);
 
            object obj = command.ExecuteScalar();
 
            if (DBNull.Value.Equals(obj))
            {
                //такого логина в бд нет
                labelERROR.Text = "Неверный логин или пароль";
                myConnection.Close();
            }
            else
            {
                // такой логин есть в базе
                labelERROR.Text = "Такое есть";
                myConnection.Close();
            }
        }
Его подсмотрела в одной из тем на этом же форуме, но здесь проблема в том, что даже при неправильном вводе, заходит в блок else и пишет, что все верно.

С БД начала работать недавно, может кто-то может помочь решить эту проблему?
Запрос проверила в MSQL Managment Studio, там все верно выводит. Находит совпадение и выводит нужные ячейки. А здесь работает неверно.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
15.07.2021, 22:54
Ответы с готовыми решениями:

Проверка на пустой запрос
Пользователь вводит имя через textbox (tbName) и пароль в PasswordBox. Имена и пароли хранятся в столбцах Name и Password таблицы Employee...

Если возвращается переменная ссылочного типа, то возвращается объект или просто ссылка
Почему-то авторы всегда акцентируют внимание на передачу параметров в функцию, а на возврат не очень: using System; using...

Почему возвращается пустой массив
function range(start, end) { let resultMassive = ; for(let i = start; i<=end;i++) { ...

3
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18298 / 14222 / 5368
Регистрация: 17.03.2014
Сообщений: 28,900
Записей в блоге: 1
16.07.2021, 00:11
Tora190, так попробуйте
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
private void BTN_Run_Click(object sender, EventArgs e)
{
    if (IsValidUserAndPassword(TB_Login.Text, TB_Password.Text))
    {
        //Все верно
        labelERROR.Text = "Такое есть";
    }
    else
    {
        //Что-то не так
        labelERROR.Text = "Неверный логин или пароль";
    }
}
 
const string connectString = "Data Source=.\\SQLEXPRESS;Initial Catalog=CompanyDataBase; Integrated Security=True";
 
static bool IsValidUserAndPassword(string login, string password)
{
    using SqlConnection myConnection = new SqlConnection(connectString);
 
    myConnection.Open();
 
    const string query = "SELECT COUNT(*) FROM [ЛИЧНЫЙ_КАБИНЕТ] WHERE ЛОГИН = @Login AND ПАРОЛЬ = @Password";
 
    SqlCommand command = new SqlCommand(query, myConnection);
 
    command.Parameters.AddWithValue("@Login", login);
    command.Parameters.AddWithValue("@Password", password);
    
    return 1 == (int)command.ExecuteScalar();
}
0
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
16.07.2021, 18:01
Tora190,
1. Если Вы пишете в SQL предикат Like, то следует снабдить его вилдкартами:
SQL
1
SELECT * FROM MyTable WHERE login LIKE '%Ваня%'
2. Очень странная авторизация. Если юзер введет "а", то выберется куча записей с этой буквой : "Вася", "Наталья", "Кандибобер трасовый" и т.д.

3. Если в базе у Вас таблицы и/или поля названы "грязными" именами (кириллицей например), то следует везде брать их в брэкеты [] во избежание несваримости желудка SQL Server от подобных "гаек".
0
0 / 0 / 0
Регистрация: 06.09.2019
Сообщений: 21
17.07.2021, 18:03  [ТС]
Спасибо большое, все работает.

Добавлено через 2 минуты
MsGuns, спасибо. Замечания учту.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
17.07.2021, 18:03
Помогаю со студенческими работами здесь

Возвращается пустой POST если русская строка
Если в пост передавать русские символы то возращается string(0) - пустая строка, если латинские то всё норм. Как победить это?

При запросе напрямую к серверу,возвращается пустой ответ,а при использовании проксей для отладки все работает
Пробовал несколько раз,если прокси работают,то сервер возвращает ответ.Если на прямую,то пустую строку.В качестве проксей использовался...

Отправляем файл через FormData(), запрос есть, а массив $_FILES пустой (сервер не может распарсить запрос?)
Код практически весь из мурзилки отсюда Задача - отправить файл черех Ajax, поместив в FormData(); Скажу сразу: данные, если верить...

Пустой запрос
Помогите пожалуйста разобраться в чем ошибка. Есть бд mysql, в которую пишутся заметки (наименование и дата), при выборе даты в delphi...

Пустой запрос
Все здравствуйте, прошу помощи, уже пятый вечер бьюсь с задачей и никак не могу осилить. В общем, задача: есть три документа (СчВоды,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru