C# WPF入门学习番外篇(二) —— C# WPF使用数据库创建注册登录界面

本文主要是介绍C# WPF入门学习番外篇(二) —— C# WPF使用数据库创建注册登录界面,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

C# WPF入门学习番外篇(二) —— C# WPF使用数据库创建注册登录界面

在这里插入图片描述

在这篇番外篇博客中,我们将介绍如何在C# WPF应用程序中使用数据库来创建一个简单的注册和登录界面。通过本教程,你将学习到如何在WPF中与数据库进行交互,以及如何实现用户注册和登录功能。

1. 准备工作

首先,确保你已经安装了必要的工具和库:

  • Visual Studio
  • MySQL数据库(或其他你选择的数据库)
  • MySQL Connector/NET(通过NuGet安装 MySql.Data 包)

准备工作在上一篇番外篇中已经讲过啦~
C# WPF入门学习番外篇(一)——C#使用WPF连接MySQL数据库

2. 配置数据库

创建一个名为 UserDB 的数据库,并创建一个名为 Users 的表:

CREATE DATABASE UserDB;
USE UserDB;CREATE TABLE Users (Id INT AUTO_INCREMENT PRIMARY KEY,Username VARCHAR(50) NOT NULL,Password VARCHAR(50) NOT NULL
);

这里说明一下我是用的MySQL,软件我用的jetbrains家的DataGrip,当然没有的话也不影响,可以使用MySQL自带的终端来对数据库进行操作。
在这里插入图片描述

3. 创建WPF项目

在Visual Studio中创建一个新的WPF项目。

4. 配置连接字符串

在项目的 App.config 文件中添加数据库连接字符串:

<configuration><connectionStrings><add name="UserDBConnectionString" connectionString="Server=localhost;Database=UserDB;User Id=myusername;Password=mypassword;" providerName="MySql.Data.MySqlClient" /></connectionStrings>
</configuration>

确保替换 myusernamemypassword 为你的数据库用户名和密码。

5. 创建WPF界面

MainWindow.xaml 中,设计一个简单的界面,包括注册和登录功能:

<Window x:Class="WpfApp.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"Title="User Registration and Login" Height="400" Width="300"><Grid Margin="0,0,-4,0"><Grid.ColumnDefinitions><ColumnDefinition/></Grid.ColumnDefinitions><TextBox x:Name="txtUsername" Margin="95,111,40,228"/><PasswordBox x:Name="txtPassword"  Margin="95,160,40,179"/><Button Content="Register" Click="Register_Click" Margin="77,291,72,19"/><Button Content="Login" Click="Login_Click" Margin="77,210,72,100"/><Label Content="账号" HorizontalAlignment="Left" Margin="50,111,0,0" VerticalAlignment="Top" Height="35"/><Label Content="密码" HorizontalAlignment="Left" Margin="50,160,0,0" VerticalAlignment="Top" Height="35"/><Label Content="注册" HorizontalAlignment="Left" Margin="10,40,0,0" VerticalAlignment="Top" Height="39" Width="280" FontSize="22" HorizontalContentAlignment="Center"/></Grid>
</Window>

在这里插入图片描述

6. 编写后台代码

MainWindow.xaml.cs 中,添加注册和登录的逻辑:

using System;
using System.Windows;
using MySql.Data.MySqlClient;
using System.Configuration;namespace WpfApp
{public partial class MainWindow : Window{string connectionString = ConfigurationManager.ConnectionStrings["UserDBConnectionString"].ConnectionString;public MainWindow(){InitializeComponent();}private void Register_Click(object sender, RoutedEventArgs e){string username = txtUsername.Text;string password = txtPassword.Password;if (string.IsNullOrWhiteSpace(username) || string.IsNullOrWhiteSpace(password)){MessageBox.Show("Username and password cannot be empty.");return;}try{using (MySqlConnection conn = new MySqlConnection(connectionString)){conn.Open();string query = "INSERT INTO Users (Username, Password) VALUES (@username, @password)";MySqlCommand cmd = new MySqlCommand(query, conn);cmd.Parameters.AddWithValue("@username", username);cmd.Parameters.AddWithValue("@password", password);cmd.ExecuteNonQuery();}MessageBox.Show("Registration successful.");}catch (Exception ex){MessageBox.Show("Error: " + ex.Message);}}private void Login_Click(object sender, RoutedEventArgs e){string username = txtUsername.Text;string password = txtPassword.Password;if (string.IsNullOrWhiteSpace(username) || string.IsNullOrWhiteSpace(password)){MessageBox.Show("Username and password cannot be empty.");return;}try{using (MySqlConnection conn = new MySqlConnection(connectionString)){conn.Open();string query = "SELECT COUNT(*) FROM Users WHERE Username = @username AND Password = @password";MySqlCommand cmd = new MySqlCommand(query, conn);cmd.Parameters.AddWithValue("@username", username);cmd.Parameters.AddWithValue("@password", password);int count = Convert.ToInt32(cmd.ExecuteScalar());if (count > 0){MessageBox.Show("Login successful.");}else{MessageBox.Show("Invalid username or password.");}}}catch (Exception ex){MessageBox.Show("Error: " + ex.Message);}}}
}

详细说明

  1. 安装 MySQL Connector/NET

    • 使用 NuGet 安装 MySql.Data 包,这个包提供了与 MySQL 服务器通信所需的所有类。
  2. 配置连接字符串

    • App.config 中配置连接字符串,以便应用程序可以连接到数据库。
  3. 编写 WPF 界面

    • 设计一个简单的注册和登录界面,包含用户名和密码输入框,以及注册和登录按钮。
  4. 编写后台代码

    • 使用 MySqlConnection 类连接到数据库。
    • 在注册按钮点击事件中,执行插入操作将新用户信息保存到数据库中。
    • 在登录按钮点击事件中,执行查询操作验证用户信息。

总结

通过这个教程,你学会了如何在WPF应用程序中连接并使用MySQL数据库,创建一个基本的用户注册和登录界面。你可以根据需要扩展这个示例,添加更多功能和验证逻辑,以构建一个更复杂和完整的应用程序。


这篇关于C# WPF入门学习番外篇(二) —— C# WPF使用数据库创建注册登录界面的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1057137

相关文章

pandas DataFrame keys的使用小结

《pandasDataFramekeys的使用小结》pandas.DataFrame.keys()方法返回DataFrame的列名,类似于字典的键,本文主要介绍了pandasDataFrameke... 目录Pandas2.2 DataFrameIndexing, iterationpandas.DataF

使用Python和PaddleOCR实现图文识别的代码和步骤

《使用Python和PaddleOCR实现图文识别的代码和步骤》在当今数字化时代,图文识别技术的应用越来越广泛,如文档数字化、信息提取等,PaddleOCR是百度开源的一款强大的OCR工具包,它集成了... 目录一、引言二、环境准备2.1 安装 python2.2 安装 PaddlePaddle2.3 安装

嵌入式Linux之使用设备树驱动GPIO的实现方式

《嵌入式Linux之使用设备树驱动GPIO的实现方式》:本文主要介绍嵌入式Linux之使用设备树驱动GPIO的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、设备树配置1.1 添加 pinctrl 节点1.2 添加 LED 设备节点二、编写驱动程序2.1

使用Python开发Markdown兼容公式格式转换工具

《使用Python开发Markdown兼容公式格式转换工具》在技术写作中我们经常遇到公式格式问题,例如MathML无法显示,LaTeX格式错乱等,所以本文我们将使用Python开发Markdown兼容... 目录一、工具背景二、环境配置(Windows 10/11)1. 创建conda环境2. 获取XSLT

Python中Flask模板的使用与高级技巧详解

《Python中Flask模板的使用与高级技巧详解》在Web开发中,直接将HTML代码写在Python文件中会导致诸多问题,Flask内置了Jinja2模板引擎,完美解决了这些问题,下面我们就来看看F... 目录一、模板渲染基础1.1 为什么需要模板引擎1.2 第一个模板渲染示例1.3 模板渲染原理二、模板

浅析如何使用xstream实现javaBean与xml互转

《浅析如何使用xstream实现javaBean与xml互转》XStream是一个用于将Java对象与XML之间进行转换的库,它非常简单易用,下面将详细介绍如何使用XStream实现JavaBean与... 目录1. 引入依赖2. 定义 JavaBean3. JavaBean 转 XML4. XML 转 J

使用Python创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

在.NET平台使用C#为PDF添加各种类型的表单域的方法

《在.NET平台使用C#为PDF添加各种类型的表单域的方法》在日常办公系统开发中,涉及PDF处理相关的开发时,生成可填写的PDF表单是一种常见需求,与静态PDF不同,带有**表单域的文档支持用户直接在... 目录引言使用 PdfTextBoxField 添加文本输入域使用 PdfComboBoxField

Git可视化管理工具(SourceTree)使用操作大全经典

《Git可视化管理工具(SourceTree)使用操作大全经典》本文详细介绍了SourceTree作为Git可视化管理工具的常用操作,包括连接远程仓库、添加SSH密钥、克隆仓库、设置默认项目目录、代码... 目录前言:连接Gitee or github,获取代码:在SourceTree中添加SSH密钥:Cl

MySQL数据库约束深入详解

《MySQL数据库约束深入详解》:本文主要介绍MySQL数据库约束,在MySQL数据库中,约束是用来限制进入表中的数据类型的一种技术,通过使用约束,可以确保数据的准确性、完整性和可靠性,需要的朋友... 目录一、数据库约束的概念二、约束类型三、NOT NULL 非空约束四、DEFAULT 默认值约束五、UN