.NET(C#) 操作 h2 数据库【记录整个研究过程...】

本文记录了使用C#操作Java的H2数据库的过程。从发现H2数据库,验证其数据存储,到尝试.NET连接H2,以及遇到的方法未实现异常问题。作者通过IKVM.NET将H2.jar转换为.dll,但遇到版本不匹配的问题,最终决定使用Java编写测试程序进行连接。
摘要由CSDN通过智能技术生成

发现h2数据库

说到为什么要用C#来调用Java数据库h2,原因是制作了一个C#的工具,来对网页服务进行部署,主要是进行一些环境的检查,因为对C#比较熟悉,所以就首先选择了C#语言来做winform程序。
但是当这个程序完成以后,发现winform需要和部署的页面中一些显示数据进行交互,这个时候通过页面上的调试分析无法找到这个数据是怎么来的,后来请搞前端的朋友帮忙查看后发现它的数据读写都封装在jar包,使用JD-GUI工具对jar包查看,结果操作数据的类做过混淆没法反编译,不过发现配置文件中暗藏一些内容,既有对应的sql语句,又有数据库连接账号密码,同时注意到了jdbc:h2,百度查一下,原来这是Java中的一种数据库。
因此出来一种思路,找一个办法,直接使用C#来操作这个数据库
在这里插入图片描述
在这里插入图片描述

验证h2数据库

虽然通过JD-GUI的结果初步判断数据保存在这个h2数据库中,但是对这个新鲜的玩意不太熟悉,所以我先需要验证一下这个东西是哪个文件?它里面保存了我想要的数据吗?
带着问题首先通过上面

spring.datasource.url=jdbc:h2:file:....

通过后面出现的值找到db文件
在这里插入图片描述
(其实最开始没搞过Java没看懂这个写法,把h2当成了语法的一种;以为这个是SQLit之类的数据库,就使用Navicat Premium这样的数据库工具尝试了很久,发现都无法打开这个文件)

最后通过DbVisualizer工具打开
不过使用该工具打开的时候需要注意一个问题,也是我在尝试的时候才发现:
①如果使用H2 embedded方式打开文件,即使选择的是正确的.db文件,它仅仅是在同级目录下创建了一个选中文件名+.mv.db的文件,并将新文件打开(选中文件并未被打开),并且新的数据库文件中不存在任何数据,这个开始困扰了我一会儿,让我一时思考是不是找错文件了。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

②所以正确的打开方式是使用H2 server方式连接数据库
在这里插入图片描述
Setting Format 需要修改为Database URL
在这里插入图片描述
至于后面的URL ,我参考jar包中提供的设置

spring.datasource.url=jdbc:h2:file:文件路径

不过此处文件路径每一级目录需要两个\,并且最后的不是文件全名
例如:
在这里插入图片描述
输入账号密码连接成功后
在这里插入图片描述
这样就可以在查数据了,经过验证,我所需要的数据的确是在某一张表中,验证成功,接下来就是如何在我的C#工程读取数据库了。

.NET是否能连接h2呢?

在网上百度了一圈,通过诸如什么“C#连接h2数据库”“C# h2”“.net h2”…各种条件搜索,结果出来的全是什么“C#连接MySQL”“h2入门”…之类,让我对是否能成功产生了巨大的怀疑

在这里插入图片描述

还有孤单的提问者

好的,下面是一个简单的ASP.NET图书借阅系统的登录注册模块的代码实现: 首先,在ASPX文件中设计登录和注册页面的CSS界面,可以使用Bootstrap等框架进行快速构建。 登录页面的ASPX代码如下: ``` <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Login.aspx.cs" Inherits="Login" %> <!DOCTYPE html> <html> <head> <title>登录</title> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> <link href="Content/bootstrap.min.css" rel="stylesheet" /> </head> <body> <div class="container"> <h2>登录</h2> <form method="post" action="Login.aspx"> <div class="form-group"> <label for="txtUsername">用户名:</label> <input type="text" class="form-control" id="txtUsername" name="txtUsername" placeholder="请输入用户名" required /> </div> <div class="form-group"> <label for="txtPassword">密码:</label> <input type="password" class="form-control" id="txtPassword" name="txtPassword" placeholder="请输入密码" required /> </div> <button type="submit" class="btn btn-primary">登录</button> </form> <p>还没有账号?<a href="Register.aspx">点击注册</a></p> </div> <script src="Scripts/jquery-3.3.1.min.js"></script> <script src="Scripts/bootstrap.min.js"></script> </body> </html> ``` 注册页面的ASPX代码如下: ``` <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Register.aspx.cs" Inherits="Register" %> <!DOCTYPE html> <html> <head> <title>注册</title> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> <link href="Content/bootstrap.min.css" rel="stylesheet" /> </head> <body> <div class="container"> <h2>注册</h2> <form method="post" action="Register.aspx"> <div class="form-group"> <label for="txtUsername">用户名:</label> <input type="text" class="form-control" id="txtUsername" name="txtUsername" placeholder="请输入用户名" required /> </div> <div class="form-group"> <label for="txtPassword">密码:</label> <input type="password" class="form-control" id="txtPassword" name="txtPassword" placeholder="请输入密码" required /> </div> <div class="form-group"> <label for="txtConfirmPassword">确认密码:</label> <input type="password" class="form-control" id="txtConfirmPassword" name="txtConfirmPassword" placeholder="请确认密码" required /> </div> <div class="form-group"> <label for="txtEmail">邮箱:</label> <input type="email" class="form-control" id="txtEmail" name="txtEmail" placeholder="请输入邮箱" required /> </div> <button type="submit" class="btn btn-primary">注册</button> </form> <p>已有账号?<a href="Login.aspx">点击登录</a></p> </div> <script src="Scripts/jquery-3.3.1.min.js"></script> <script src="Scripts/bootstrap.min.js"></script> </body> </html> ``` 接着,编写C#代码连接数据库sqlserver2008进行设计。 首先,需要在Web.config文件中添加数据库连接字符串,如下所示: ``` <connectionStrings> <add name="ConnectionString" connectionString="Data Source=localhost;Initial Catalog=Library;User ID=sa;Password=123456;" providerName="System.Data.SqlClient" /> </connectionStrings> ``` 其中,Data Source为数据库服务器地址,Initial Catalog为数据库名称,User ID为登录数据库的用户名,Password为登录数据库的密码。 在C#代码中,可以使用ADO.NET进行数据库操作。具体实现如下: 在Login.aspx.cs文件中,编写登录功能的代码: ``` using System; using System.Data; using System.Data.SqlClient; public partial class Login : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { } protected void btnLogin_Click(object sender, EventArgs e) { string username = txtUsername.Text.Trim(); string password = txtPassword.Text.Trim(); string sql = "SELECT * FROM Users WHERE Username=@Username AND Password=@Password"; SqlConnection conn = new SqlConnection(System.Configuration.ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString); SqlCommand cmd = new SqlCommand(sql, conn); cmd.Parameters.AddWithValue("@Username", username); cmd.Parameters.AddWithValue("@Password", password); SqlDataAdapter da = new SqlDataAdapter(cmd); DataTable dt = new DataTable(); da.Fill(dt); if (dt.Rows.Count > 0) { Session["UserID"] = dt.Rows[0]["UserID"]; Response.Redirect("Default.aspx"); } else { lblMessage.Text = "用户名或密码错误!"; } } } ``` 其中,txtUsername和txtPassword为登录页面中的用户名和密码输入框,btnLogin为登录按钮,lblMessage为显示错误信息的标签。 在Register.aspx.cs文件中,编写注册功能的代码: ``` using System; using System.Data; using System.Data.SqlClient; public partial class Register : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { } protected void btnRegister_Click(object sender, EventArgs e) { string username = txtUsername.Text.Trim(); string password = txtPassword.Text.Trim(); string email = txtEmail.Text.Trim(); string sql = "INSERT INTO Users (Username, Password, Email) VALUES (@Username, @Password, @Email)"; SqlConnection conn = new SqlConnection(System.Configuration.ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString); SqlCommand cmd = new SqlCommand(sql, conn); cmd.Parameters.AddWithValue("@Username", username); cmd.Parameters.AddWithValue("@Password", password); cmd.Parameters.AddWithValue("@Email", email); conn.Open(); int result = cmd.ExecuteNonQuery(); conn.Close(); if (result > 0) { Response.Redirect("Login.aspx"); } else { lblMessage.Text = "注册失败!"; } } } ``` 其中,txtUsername、txtPassword和txtEmail为注册页面中的用户名、密码和邮箱输入框,btnRegister为注册按钮,lblMessage为显示错误信息的标签。 以上就是一个简单的ASP.NET图书借阅系统的登录注册模块的代码实现。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值