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数据库,创建一个基本的用户注册和登录界面。你可以根据需要扩展这个示例,添加更多功能和验证逻辑,以构建一个更复杂和完整的应用程序。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/851740.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网格细分技术在AI绘画中的革新应用

导语&#xff1a; 随着人工智能技术的不断突破&#xff0c;艺术创作也迈入了一个新的时代。AI绘画不仅为艺术家提供了新的工具和灵感源泉&#xff0c;还极大地扩展了艺术的边界。在这背后&#xff0c;网格细分技术扮演着至关重要的角色&#xff0c;它通过将画面划分为数以万计的…

Android低代码开发 - 直接创建一个下拉刷新列表界面

看了我Android低代码开发 - 让IDE帮你写代码这篇文章的小伙伴&#xff0c;大概都对Dora全家桶开发框架有基本的认识了吧。本篇文章将会讲解如何使用dora-studio-plugin快捷创建一个下拉刷新列表界面。 效果演示 这样直接通过图形界面的方式就创建好了下拉刷新上拉加载空态界面…

旅游行业电商平台:数字化转型的引擎与未来发展趋势

引言 旅游行业数字化转型的背景和重要性 随着信息技术的飞速发展&#xff0c;数字化转型成为各行业发展的必然趋势。旅游行业&#xff0c;作为一个高度依赖信息和服务的领域&#xff0c;数字化转型尤为重要。通过数字化手段&#xff0c;旅游行业能够实现资源的高效配置、服务的…

用映射对比ab俩个数组 , 并把a的参数传递给b

项目背景 : react ant 需求 : 在项目进行表头设置时,根据aaa中的key和bbb中的name对应 , 并将sort值插入到bbb中 其中 a b 结构如下 具体实现 aaa[ { key: "orderNumber", orderNumber: "工单编号", sort: 1 } ... ]bbb [ { name: "orderNumber…

Jenkins For Windows编译构建C#项目环境搭建(完整版)

安装Jenkins 下载Windows安装包 官方下载地址 选择稳定版&#xff0c;这里下载的是最新版&#xff0c;如需下载指定版本点击 以前的发行版 配置java环境 下载 java jdk 17 jdk17官方下载链接 这里下载的是msi版本的安装包 安装jdk17 双击运行安装包&#xff0c;一直下…

【Android】Android获取设备Serial Number的方法

项目需求 获取Android 9 和Android 11的设备的SN序列号 解决方案 1.Android 9 获取方式 这个是Android官方提供的方法&#xff0c;可以获取到Android 8/9 的设备的SN号 String serial Build.SERIAL;Android 11 获取方式 Android 11 已经禁止了上面的这种方法&#xff0c;获…

3D数字化营销——电商行业提升转化率,降低退货率的杀手锏!

随着3D、AR等前沿技术的蓬勃发展&#xff0c;电商行业正迎来一场3D数字化营销的革命。这种创新的营销方式不仅极大地丰富了商品的展现形式&#xff0c;还成功弥补了传统电商在临场感和体验感方面的不足&#xff0c;从而显著提升了消费者的购物体验。 51建模网为电商行业提供3D…

Java面试题-进阶

Java面试题-进阶 1、分布式幂等性如何设计?2、说说你对分布式事务的了解?3、分布式事务的解决方案有哪些?4、分布式事务的二阶段提交是什么?5、分布式事务中的三阶段提交是什么?6、什么是分布式ID?7、分布式ID有什么特性?8、分布式ID生成有几种方案?9、分布式系统中幂等…

WebSocket 快速入门 与 应用

WebSocket 是一种在 Web 应用程序中实现实时、双向通信的技术。它允许客户端和服务器之间建立持久性的连接&#xff0c;以便可以在两者之间双向传输数据。 以下是 WebSocket 的一些关键特点和工作原理&#xff1a; 0.特点&#xff1a; 双向通信&#xff1a;WebSocket 允许服务…

Mocha + Chai 测试环境配置,支持 ES6 语法

下面是一个完整的 Mocha Chai 测试环境配置&#xff0c;支持 ES6 语法。我们将使用 Babel 来转译 ES6 代码。 步骤一&#xff1a;初始化项目 首先&#xff0c;在项目目录中运行以下命令来初始化一个新的 Node.js 项目&#xff1a; npm init -y步骤二&#xff1a;安装必要的…

[AI Stability] 开源AI新利器:Stable Diffusion 3 Medium震撼发布!文本到图像再升级!

Stable Diffusion 3 Medium(SD3) 开源了&#xff0c;我们来看下。 关键要点 Stable Diffusion 3 Medium 是 Stability AI 迄今为止最先进的文本到图像开源模型。该模型的体积小巧&#xff0c;非常适合在消费级 PC 和笔记本电脑上运行&#xff0c;也适合在企业级 GPU 上运行。…

### RabbitMQ五种工作模式:

RabbitMQ五种工作模式&#xff1a; 1、简单模式&#xff1a;就是不通过交换机&#xff0c;消息直接通过队列&#xff0c;一对一收发。 2、工作队列模式&#xff1a;也是不通过交换机&#xff0c;消息直接通过队列&#xff0c;只是一个发送方可以有多个接收端。 3、发布订阅模…

2024年科技趋势与未来展望

引言 2024年已经到来&#xff0c;科技领域正在以前所未有的速度发展。从人工智能到量子计算&#xff0c;再到绿色科技&#xff0c;每一个领域都在经历着巨大的变革。这篇文章将探讨2024年最值得关注的科技趋势&#xff0c;并对未来的科技发展进行展望。 1. 人工智能与机器学习…

产品经理简要介绍主流电商平台商品API接口的重要应用价值

主流电商平台&#xff1a; 截至目前&#xff08;2024年6月&#xff09;&#xff0c;主流电商平台通常指的是国内外知名的在线购物平台&#xff0c;包括但不限于以下几家&#xff1a; 1. 中国电商平台&#xff1a; - 淘宝网&#xff08;taobao.com&#xff09; - 天猫商…

端午消费数据:“下沉”“价跌”延续

端午假期消费延续了五一的“下沉”与“价跌”趋势。一是人均旅游支出的恢复程度&#xff0c;仍不及2019年&#xff08;恢复至89.5%&#xff09;&#xff1b;二是三线以下城市继续成为旅游新增长点&#xff0c;其平台订单热度高于部分一线和新一线城市。三是国内、国际机票酒店价…

宝塔面板怎么搭建网站论坛

宝塔面板怎么搭建网站论坛?在数字化时代&#xff0c;网站已经成为企业展示形象、推广产品、服务客户的重要窗口。然而&#xff0c;对于许多初次接触建站的朋友来说&#xff0c;如何快速、便捷地搭建一个功能齐全、稳定可靠的网站&#xff0c;却是一个不小的挑战。今天&#xf…

自动同步库数据——kettle开发36

kettle中的那些人工智能。 一、kettle的AI能力目录 跨库同步 2.自动开发 3.自动优化 二、AI实例 1、跨库同步 sqlsever表同步至oracle数据库 1.1源库sqlserver 1.2目标库oracle 1.3可视化跨库同步 使用多表复制向导 选择跨库的表&#xff0c;下一步下一步&#xff0c;即可…

【JavaScript脚本宇宙】交互无限可能:探索JavaScript库的交互性魔力

手到擒来&#xff1a;JavaScript库助力网页交互功能提升 前言 在Web开发中&#xff0c;使用合适的JavaScript库可以大大简化实现各种交互功能的复杂性。本文将介绍一些常用的JavaScript库&#xff0c;包括用于拖动、调整大小、多点触控手势、创建可拖动和可调整大小的网格布局…

餐厅吃饭优惠笔记

1 闲鱼&#xff1a;电子优惠券 亚马逊自助餐厅&#xff08;亚马逊环球美食百汇&#xff09;

Javaweb避坑指北(持续更新)

内容较多可按CtrlF搜索 0.目录 1.获取插入数据后自增长主键的值 2.Controller中返回给ajax请求字符串/json会跳转到xxx.jsp 3.ajax请求获得的json无法解析 4.在Controller中使用ServletFileUpload获取的上传文件为null 5.莫名其妙报service和dao里方法的错误 6.ajax请求拿…