Auth.xaml.cs 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data;
  4. using System.Data.SqlClient;
  5. using System.Linq;
  6. using System.Text;
  7. using System.Threading.Tasks;
  8. using System.Windows;
  9. using System.Windows.Controls;
  10. using System.Windows.Data;
  11. using System.Windows.Documents;
  12. using System.Windows.Input;
  13. using System.Windows.Media;
  14. using System.Windows.Media.Imaging;
  15. using System.Windows.Shapes;
  16. namespace veloprokat2
  17. {
  18. /// <summary>
  19. /// Логика взаимодействия для Auth.xaml
  20. /// </summary>
  21. public partial class Auth : Window
  22. {
  23. VeloprokatEntities db;
  24. public Auth()
  25. {
  26. InitializeComponent();
  27. db = new VeloprokatEntities();
  28. }
  29. private void Voyti(object sender, RoutedEventArgs e)
  30. {
  31. if (Login.Text.Length > 0) // проверяем введён ли логин
  32. {
  33. if (Pass.Password.Length > 0) // проверяем введён ли пароль
  34. { // ищем в базе данных пользователя с такими данными
  35. DataTable InfoAdm = Select("SELECT * FROM [dbo].[InfoAdm] WHERE [Login] = '" + Login.Text + "' AND [Password] = '" + Pass.Password + "'");
  36. DataTable InfoRab = Select("SELECT * FROM [dbo].[InfoRab] WHERE [Login] = '" + Login.Text + "' AND [Password] = '" + Pass.Password + "'");
  37. if (InfoAdm.Rows.Count > 0 ) // если такая запись существует
  38. {
  39. MessageBox.Show("Пользователь авторизовался"); // говорим, что авторизовался
  40. Login.Background = Brushes.Transparent;
  41. Pass.Background = Brushes.Transparent;
  42. MainWindowAdm AWM = new MainWindowAdm();
  43. AWM.Show();
  44. Close();
  45. }
  46. else if (InfoRab.Rows.Count > 0)
  47. {
  48. MessageBox.Show("Пользователь авторизовался"); // говорим, что авторизовался
  49. Login.Background = Brushes.Transparent;
  50. Pass.Background = Brushes.Transparent;
  51. MainWindowProd AMP = new MainWindowProd();
  52. AMP.Show();
  53. Close();
  54. }
  55. else MessageBox.Show("Пользователь не найден"); // выводим ошибку
  56. }
  57. else
  58. {
  59. MessageBox.Show("Введите пароль"); // выводим ошибку
  60. Pass.Background = Brushes.DarkRed;
  61. }
  62. }
  63. else
  64. {
  65. MessageBox.Show("Введите логин"); // выводим ошибку
  66. Login.Background = Brushes.DarkRed;
  67. }
  68. /*string login = Login.Text.Trim();
  69. string pass = Pass.Password.Trim();
  70. InfoRab newInfoRab = new InfoRab()
  71. {
  72. Login = Login.Text,
  73. Password = Pass.Password,
  74. };
  75. if (db.InfoRab.Select(item => item.Login).Contains(Login.Text) && db.InfoRab.Select(item=>item.Password).Contains(Pass.Password))
  76. {
  77. MainWindowProd MWP = new MainWindowProd();
  78. MWP.Show();
  79. Close();
  80. }
  81. else if (db.InfoAdm.Select(item=> item.Login).Contains(Login.Text) && db.InfoAdm.Select(item=>item.Password).Contains(Pass.Password))
  82. {
  83. MainWindowAdm MWA = new MainWindowAdm();
  84. MWA.Show();
  85. Close();
  86. }*/
  87. }
  88. public DataTable Select(string selectSQL) // функция подключения к базе данных и обработка запросов
  89. {
  90. DataTable dataTable = new DataTable("dataBase"); // создаём таблицу в приложении
  91. // подключаемся к базе данных
  92. SqlConnection sqlConnection = new SqlConnection("server=DESKTOP-9UG7OCA;Trusted_Connection=Yes;DataBase=Veloprokat;");
  93. sqlConnection.Open(); // открываем базу данных
  94. SqlCommand sqlCommand = sqlConnection.CreateCommand(); // создаём команду
  95. sqlCommand.CommandText = selectSQL; // присваиваем команде текст
  96. SqlDataAdapter sqlDataAdapter = new SqlDataAdapter(sqlCommand); // создаём обработчик
  97. sqlDataAdapter.Fill(dataTable); // возращаем таблицу с результатом
  98. return dataTable;
  99. }
  100. }
  101. }