quot;connection rejected by remote interfacequot; in C# program connecting to Firebird 3(连接被连接到Firebird 3的C#程序中的远程接口拒绝(Q))
问题描述
从Firebird 2.5迁移到3.0后,当我尝试使用C#程序测试数据库的连接时,显示此错误"Connection Reduced by Remote Interface."
以下是测试连接的代码,我在尝试连接到Firebird 2.5数据库时使用此代码。
txtPassword.Properties.UseSystemPasswordChar = true;
txtHostname.Text = Properties.Settings.Default.server;
txtUsername.Text = Properties.Settings.Default.user;
txtPassword.Text = Properties.Settings.Default.pass;
txtDBPath.Text = Properties.Settings.Default.dbpath;
void Testdbconn()
{
try
{
var testInMemUnicode =
String.Format("DataSource={0};Database={1};User ID={2};Password={3}; Charset=NONE;",
txtHostname.Text,
txtHostname.Text + ":" + txtDBPath.Text.Trim(),
txtUsername.Text,
txtPassword.Text);
var testConnParam = new FbConnection(testInMemUnicode);
testConnParam.Open();
XtraMessageBox.Show(@"Connection to the server is successful.", @"Data Server Test",
MessageBoxButtons.OK,
MessageBoxIcon.Information);
}
catch (Exception errorCode)
{
XtraMessageBox.Show(@"Error in connection: " + errorCode.Message,
@"Server Error",
MessageBoxButtons.OK,
MessageBoxIcon.Exclamation);
}
}
class ClsConnection
{
public static string FirebirdSQL = String.Format(
"DataSource={0}; Database={1}; User ID={2}; Password={3}; Charset=NONE; Port=3050; Dialect=3;" +
"Connection lifetime=15; Pooling=true; MinPoolSize=0; MaxPoolSize=2000000; Packet Size=8192; ServerType=0",
Properties.Settings.Default.server, Properties.Settings.Default.db + ":" + Properties.Settings.Default.dbpath,
Properties.Settings.Default.user, Properties.Settings.Default.pass);
private static readonly string FirebirdService = FirebirdSQL;
/// <summary>
///
/// </summary>
public static FbConnection Firebird = new FbConnection(FirebirdService);
/// <summary>
///
/// </summary>
public void Openconnection()
{
if (Firebird.State == System.Data.ConnectionState.Open)
{
Firebird.Close();
}
Firebird.Open();
}
/// <summary>
///
/// </summary>
public void Closeconnection()
{
Firebird.Close();
}
}
推荐答案
对于此答案,我假设您使用的是最新的Firebird ADO.Net版本(例如5.12.0.0,但至少是5.0.0.0)。
Firebird 3引入了有线协议加密,这在默认情况下是必需的。在撰写本文时,Firebird ADO.NET提供程序不支持这种加密。因此,连接尝试将失败,并显示错误"远程接口拒绝连接"(错误代码335544421)。
解决方案是修改Firebird配置以仅启用而不需要有线协议加密。为此,请编辑Firebird服务器的firebird.conf并将设置WireCrypt更改为WireCrypt = Enabled(如果当前以#为前缀,则删除#),然后重新启动Firebird服务器。如果Firebird安装在Program Files中,则需要以管理员权限运行您的编辑器才能正确保存文件。
请注意,在客户端和服务器之间的握手不能就某些连接和协议选项达成一致的其他情况下也可能发生此错误。
这篇关于连接被连接到Firebird 3的C#程序中的远程接口拒绝(&Q)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:连接被连接到Firebird 3的C#程序中的远程接口拒绝(&Q)
基础教程推荐
- 如果有人提交恶意软件Nuget包怎么办? 2022-01-01
- 我应该在后面的代码中直接使用 Linq To SQL 还是使 2022-01-01
- C# 从 List<List<int>> 中删除重 2022-01-01
- Moq It.Is<>不匹配 2022-01-01
- 当值可以是对象或空数组时反序列化 JSON 2022-01-01
- 禁止输入少量字符,例如'<'、'&a 2022-01-01
- WPF 模态进度窗口 2022-01-01
- .NET SerialPort DataReceived 事件未触发 2022-01-01
- 如何使用 .Net 检查 Active Directory 服务器是否已启动并正在运行? 2022-01-01
- Azure Functions:CosmosDBTrigger 未在 Visual Studio 中触发 2022-01-01
