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

Авторизация по логину и паролю из БД

25.02.2016, 10:37. Показов 14405. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужно сделать авторизацию через c#, суть уловил, но не понимаю как в БД найти нужный мне элемент. Т.е. допустим есть БД, в ней таблица с пользователями (1 колонка - логин, 2 колонка - пароль), как мне из dataset вытащить нужную мне ячейку для сравнения?
Допустим пользователь ввел логин - Admin и пароль - qwerty. Для сравнения этих значений с соответствующими значениями в таблице мне нужно в ней найти нужную колонку и пройтись по ней, как вытащить эту самую колонку?

Добавлено через 3 минуты
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
for (int i = 0; i < worldYachtsDataSet.Tables["Users"].Rows.Count; i++) 
            {
                
                if (login.Text == )//С чем сравнить?
                {
                    if (password.Text == )//С чем сравнить?
                    {
                        this.Close();
                    }
                    else
                    {
                        label1.Text = "Вы ввели неправильный пароль";
                    }
                }
                else
                {
                    label1.Text = "Вы ввели неправильный логин";
                }
            }
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
25.02.2016, 10:37
Ответы с готовыми решениями:

Подключение к IP камерам по логину и паролю
Подключение к IP камерам по логину и паролю.

Регистрация через VK API по определенному логину и паролю
Всем привет! Пишу приложение, которое будет работать с vk api, если подробнее, то пишу плеер, через который можно будет слушать музыку с...

Авторизация по логину и паролю в таблице firebird
Всем доброго дня, пытаюсь сделать авторизацию, хочу что бы логин и пароль брались из полей в таблице firebird. Пишет ошибку...

10
0 / 0 / 1
Регистрация: 03.12.2015
Сообщений: 8
25.02.2016, 10:41
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
for (int i = 0; i < worldYachtsDataSet.Tables["Users"].Rows.Count; i++) 
            {
                
                if (login.Text == "(Нужный логин)")
                {
                    if (password.Text == "(Нужный пароль)")
                    {
                        this.Close();
                    }
                    else
                    {
                        label1.Text = "Вы ввели неправильный пароль";
                    }
                }
                else
                {
                    label1.Text = "Вы ввели неправильный логин";
                }
            }
0
2 / 2 / 0
Регистрация: 26.10.2015
Сообщений: 104
25.02.2016, 10:52  [ТС]
Логин и пароль нужно брать из БД и сравнивать их с введенным.

Добавлено через 7 минут
Решение нашел, но вылетает OurOfRange, в строке с сравнением.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
for (int i = 0; i <= worldYachtsDataSet.Tables["Users"].Rows.Count; i++) 
            {
                
                if (login.Text == worldYachtsDataSet.Tables["Users"].Rows[i][1])//Здесь
                {
                    if (password.Text == worldYachtsDataSet.Tables["Users"].Rows[i][2])//И видимо здесь также будет
                    {
                        this.Close();
                    }
                    else
                    {
                        label1.Text = "Вы ввели неправильный пароль";
                    }
                }
                else
                {
                    label1.Text = "Вы ввели неправильный логин";
                }
            }
0
 Аватар для kodv
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
25.02.2016, 12:13
Цитата Сообщение от Nakato Посмотреть сообщение
i <= worldYachtsDataSet.Tables["Users"].Rows.Count
Вы в курсе, что индекс последнего элемента коллекции будет Count-1?
0
2 / 2 / 0
Регистрация: 26.10.2015
Сообщений: 104
25.02.2016, 12:33  [ТС]
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
for (int i = 1; i == worldYachtsDataSet.Tables["Users"].Rows.Count; i++) 
            {
 
                if (login.Text==worldYachtsDataSet.Tables["Users"].Rows[i][1])
                {
                    if (password.Text==worldYachtsDataSet.Tables["Users"].Rows[i][2])
                    {
                        this.Close();
                    }
                    else
                    {
                        label1.Text = "Вы ввели неправильный пароль";
                    }
                }
                else
                {
                    label1.Text = "Вы ввели неправильный логин";
                }
            }
Пробую так, но он сразу вылетает из цикла, помогите, как решить данную проблему?
0
 Аватар для kodv
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
25.02.2016, 12:57
Nakato, "i < worldYachtsDataSet.Tables["Users"].Rows.Count"
0
2 / 2 / 0
Регистрация: 26.10.2015
Сообщений: 104
26.02.2016, 12:23  [ТС]
Цитата Сообщение от kodv Посмотреть сообщение
i < worldYachtsDataSet.Tables["Users"].Rows.Count
Так он даже не заходит в цикл...
0
 Аватар для kodv
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
26.02.2016, 12:48
Цитата Сообщение от Nakato Посмотреть сообщение
Так он даже не заходит в цикл...
значит что то вы не туда вставили. А вообще, в C# есть цикл foreach, который проходит по всей коллекции полностью, без заморочек с индексом. Может воспользовать им, если стандартные for вызывает столько трудностей?
C#
1
2
3
4
5
6
7
8
foreach(DataRow dr in worldYachtsDataSet.Tables["Users"].Rows)
    if(login.Text == dr[1])
        if(password.Text == dr[2])
            Close();
        else
            label1.Text = "Вы ввели неправильный пароль";
    else
        label1.Text = "Вы ввели неправильный логин";
PS: обращаю особое внимание на то, что в C# индексация коллекция, как правило, начинается с 0, а не с 1. Структуру вашей таблицы Users я не знаю, но если в ней всего 2 поля (login, password), оператор dr[2] вызовет знакомое вам исклчение. Правда до этой строки дайдет вряд ли, потому что вероятность того, что введенный логин совпадет с чьим-нибудь паролем, не сильно велика.
0
Эксперт .NET
 Аватар для insite2012
5548 / 4311 / 1218
Регистрация: 12.10.2013
Сообщений: 12,371
Записей в блоге: 2
28.02.2016, 08:55
Цитата Сообщение от Nakato Посмотреть сообщение
не понимаю как в БД найти нужный мне элемент
Nakato, все намного проще.
1. Создаем модель для пользователя (с моделями работать намного проще, чем со строками)
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
 
namespace NakatoDemo
{
    public class User
    {
        public string Login { get; set; }
        public string Password { get; set; }
    }
}
2. Создаем класс, который будет проверять наличие такой модели в БД (в случае такой простой задачи нам и читать ничего не надо, просто проверить свойство HasRows объекта DataReader)
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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.IO;
using System.Data;
using System.Data.SQLite;
 
namespace NakatoDemo
{
    public class SQLiteProvider
    {
        static string CONNECT_STR = string.Format("Data Source={0}",
            Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "database.db"));
 
        public void CheckUser(User user)
        {
            string selectStr = string.Format("SELECT * FROM Users WHERE login='{0}' AND password='{1}'",
                user.Login, user.Password);
            using (SQLiteConnection cnn = new SQLiteConnection(CONNECT_STR))
            {
                cnn.Open();
                using (SQLiteCommand cmd = new SQLiteCommand(selectStr, cnn))
                {
                    using (SQLiteDataReader dr = cmd.ExecuteReader())
                    {
                        if (!dr.HasRows)
                        {
                            throw new Exception("USER NOT EXISTS!");
                        }
                    }
                }
            }
        }
    }
}
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
39
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
 
namespace NakatoDemo
{
    public partial class MainForm : Form
    {
        public MainForm()
        {
            InitializeComponent();
            btnCheckUser.Click += new EventHandler(btnCheckUser_Click);
        }
 
        void btnCheckUser_Click(object sender, EventArgs e)
        {
            if (string.IsNullOrWhiteSpace(txtLogin.Text) || string.IsNullOrWhiteSpace(txtPassword.Text))
            {
                return;
            }
            SQLiteProvider provider = new SQLiteProvider();
            User temp = new User { Login = txtLogin.Text, Password = txtPassword.Text };
            try
            {
                provider.CheckUser(temp);
                MessageBox.Show("Авторизация проверена!", "Info");
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message, "Error");
            }
        }
    }
}
Примерно так. В архиве исходный код и сама БД.
Вложения
Тип файла: rar NakatoDemo.rar (493.6 Кб, 233 просмотров)
1
Эксперт .NET
 Аватар для insite2012
5548 / 4311 / 1218
Регистрация: 12.10.2013
Сообщений: 12,371
Записей в блоге: 2
28.02.2016, 08:57
kodv, кстати, добавлю, что из соображений безопасности сообщать о том, что именно введено не верно нежелательно. Лучше просто сообщить, что ошибка авторизации, без уточнения, что именно введено не верно.
0
7 / 7 / 3
Регистрация: 19.04.2016
Сообщений: 169
31.05.2016, 22:16
Правую часть нужно преобразовать в строку.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
for (int i = 0; i <= worldYachtsDataSet.Tables["Users"].Rows.Count-1; i++) 
            {
                
                if (login.Text == worldYachtsDataSet.Tables["Users"].Rows[i][1].ToString())
                {
                    if (password.Text == worldYachtsDataSet.Tables["Users"].Rows[i][2].ToString())
                    {
                        this.Close();
                    }
                    else
                    {
                        label1.Text = "Вы ввели неправильный пароль";
                    }
                }
                else
                {
                    label1.Text = "Вы ввели неправильный логин";
                }
            }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
31.05.2016, 22:16
Помогаю со студенческими работами здесь

Авторизация по логину\паролю, хранящимся в таблице sql
Добрый день всем! Извиняюсь, если тема поднималась. Делаю простую авторизацию по типу логин\пароль. Все прописано в отдельной таблице...

Вход по логину и паролю
Как можно это реализовать? для отдельного юзера. $login = 'введённый логин'; //login $pass = 'введённый пароль'; //password $path =...

Вход на сайт по логину и паролю
Здравствуйте. Как реализовать вход на сайт по логину и паролю, регистрации на сайте нет. Т.е я пользователю даю логин и пароль, он получает...

Вход на сайт по логину и паролю
нашел в интернете скрипты, мол переходит на страницу когда введешь пароль, добавил еще и логин- он не стал работать. помогите сделать...

Сделать авторизацию по логину и паролю
Добрый день пытался так сделать авторизацию по логину и паролю, не выходит, что не правильно? &lt;html&gt; &lt;head&gt; ...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru