- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
请原谅我的愚蠢,我什至不知道这是否可能。
情况是这样的。
有一个 MS Access“数据库”(是的,我知道,相信我,我知道),我需要从远程位置对其进行选择、更新和插入。问题是这需要安全地进行。
我可以完全控制托管 MS Access 文件的远程机器,因此我可以随心所欲地安装驱动程序和软件。服务器是 Microsoft Windows Server 2003。
我打算采用的方法是在 HTTPS 服务器上托管一个 PHP 脚本(使用 Apache 或 IIS,无所谓),将 XML 发送到 PHP 脚本,然后它会在 MS Access 上执行它的操作数据库并将 XML 结果发回。但是,由于时间限制,我想弄清楚我是否可以通过 ODBC 以安全的方式直接连接,并让它与 MS Access 数据库对话。
据我所知,ODBC 并不以安全着称,但有支持加密连接的 ODBC 驱动程序,或者我可以通过 SSL 以某种方式隧道化 ODBC 连接。但是,到目前为止我找到的所有信息都依赖于 Microsoft SQL 数据库。
我特别感兴趣是否有方法可以在不考虑底层数据库的情况下对 ODBC 连接进行 SSL 化。我可能可以自己在 Unix 克隆上解决这个问题,但主机是 Windows Server 2003,在这种情况下,我不知道如何继续。
这可能吗?非常感谢任何信息!
最佳答案
这里的问题是您不太了解 ODBC 连接如何与 Access 一起工作。我们在这里不是在谈论 TC/IP 或基于 socked 的连接。
如果您查看 JET Access 文件的任何连接字符串,您会在 ODBC 连接中看到,我总是重复,包括完全限定的 Windows 路径名。当我说完全限定的 Windows 路径名时,我指的是硬盘上的文件。
归根结底,我们讨论的是打开普通的 Jane Windows 文件。马是马是马,windows 文件是 windows 文件,是 windows 文件。
换句话说,我们谈论的是打开硬盘上的文件。因此,整个过程与打开 excel 文件、文本文件、PowerPoint 文件或在本例中恰好也位于硬盘上的 Access 文件没有任何不同。
没有服务器或特定的数据库软件必须安装在此文件所在的计算机上。客户端必须具有软件并执行标准的 Windows 文件打开命令以从磁盘驱动器中提取数据。请记住,当您将一个 word 文件放在服务器上并打开它时,您不必在服务器上安装 word,客户端正在打开一个 windows 标准文件,当它打开一个 Access 文件时,完全相同的场景适用于 JET .
这意味着如果您要通过 Internet 连接打开此文件,则必须通过 Internet 扩展 Windows 网络。 HTTP,甚至 FTP 与 Windows 文件网络协议(protocol)相去甚远。
但是,您可以通过 Internet 扩展 Windows 网络系统,这通常是通过称为 VPN(虚拟专用网络)的方式完成的。这意味着您必须设置 VPN。因此,这将允许您通过网络邻居查看这台计算机并浏览到服务器上该文件夹中的文件,然后简单地打开它。再次打开一个标准的 Windows 文件,服务器上没有运行某种类型的服务,您可以像使用 SQL Server 那样连接到它。
您可以阅读我的以下文章,我解释了为什么使用 Windows 网络和 JET( Access )文件在 Internet 上运行 VPN 无法以可靠的方式运行:
http://www.members.shaw.ca/AlbertKallal//Wan/Wans.html
所以请记住,如果您查看任何 JET ODBC 连接字符串,您会注意到它从来都不是基于 IP 的,而必须是完全合格的标准 Windows 文件名。我不能再强调和重复我们谈论的是我们要打开的标准 Windows 文件名和位置。
请记住,这与打开 word、excel 或 PowerPoint 没有什么不同。 ODBC 驱动程序混淆了这个问题,因为只需要在客户端安装和设置驱动程序,在服务器端没有什么可以连接两个,除了需要打开标准的纯简 Windows 文件的能力。
您因此要求尽可能使用 VPN,但不实用。您可以阅读上面的文章,它详细解释了为什么这不能可靠地工作和运行。
随着 SQL Server 的几个免费版本的出现,以及许多其他选择,上述限制对您来说可能不会成为问题。这些其他服务器数据库系统不是基于文件的,您的连接字符串永远不会解析为某个文件名。而且,因此这些数据库服务器也不需要 windows 网络原型(prototype)调用来打开该文件,因此您甚至可以连接到甚至没有安装 windows 网络的服务器,例如运行 linux 等。对于 jet 连接,您必须使用 windows 网络直接打开文件。
关于security - 与 MS Access 数据库的安全 ODBC 网络连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3401409/
我知道这个问题可能已经被问过,但我检查了所有这些,我认为我的情况有所不同(请友善)。所以我有两个数据集,第一个是测试数据集,第二个是我保存在数据框中的预测(预测值,这就是没有数据列的原因)。我想合并两
在 .loc 方法的帮助下,我根据同一数据框中另一列中的值来识别 Panda 数据框中某一列中的值。 下面给出了代码片段供您引用: var1 = output_df['Player'].loc[out
当我在 Windows 中使用 WinSCP 通过 Ubuntu 连接到 VMware 时,它提示: The server rejected SFTP connection, but it lis
我正在开发一个使用 xml web 服务的 android 应用程序。在 wi-fi 网络中连接时工作正常,但在 3G 网络中连接时失败(未找到 http 404)。 这不仅仅发生在设备中。为了进行测
我有一个XIB包含我的控件的文件,加载到 Interface Builder(Snow Leopard 上的 Xcode 4.0.2)中。 文件的所有者被设置为 someClassController
我在本地计算机上管理 MySQL 数据库,并通过运行以下程序通过 C 连接到它: #include #include #include int main(int argc, char** arg
我不知道为什么每次有人访问我网站上的页面时,都会打开一个与数据库的新连接。最终我到达了大约 300 并收到错误并且页面不再加载。我认为它应该工作的方式是,我将 maxIdle 设置为 30,这意味着
希望清理 NMEA GPS 中的 .txt 文件。我当前的代码如下。 deletes = ['$GPGGA', '$GPGSA', '$GPGSV', '$PSRF156', ] searchquer
我有一个 URL、一个用户名和一个密码。我想在 C# .Net WinForms 中建立 VPN 连接。 你能告诉我从哪里开始吗?任何第三方 API? 代码示例将受到高度赞赏... 最佳答案 您可以像
有没有更好的方法将字符串 vector 转换为字符 vector ,字符串之间的终止符为零。 因此,如果我有一个包含以下字符串的 vector "test","my","string",那么我想接收一
我正在编写一个库,它不断检查 android 设备的连接,并在设备连接、断开连接或互联网连接变慢时给出回调。 https://github.com/muddassir235/connection_ch
我的操作系统:Centos 7 + CLOUDLINUX 7.7当我尝试从服务器登录Mysql时 [root@server3 ~]# Mysql -u root -h localhost -P 330
我收到错误:Puma 发现此错误:无法打开到本地主机的 TCP 连接:9200(连接被拒绝 - 连接(2)用于“本地主机”端口 9200)(Faraday::ConnectionFailed)在我的
请给我一些解决以下错误的方法。 这是一个聊天应用....代码和错误如下:: conversations_controller.rb def create if Conversation.bet
我想将两个单元格中的数据连接到一个单元格中。我还想只组合那些具有相同 ID 的单元格。 任务 ID 名称 4355.2 参与者 4355.2 领袖 4462.1 在线 4462.1 快速 4597.1
我经常需要连接 TSQL 中的字段... 使用“+”运算符时 TSQL 强制您处理的两个问题是 Data Type Precedence和 NULL 值。 使用数据类型优先级,问题是转换错误。 1)
有没有在 iPad 或 iPhone 应用程序中使用 Facebook 连接。 这个想法是登录这个应用程序,然后能够看到我的哪些 facebook 用户也在使用该应用程序及其功能。 最佳答案 是的。
我在连接或打印字符串时遇到了一个奇怪的问题。我有一个 char * ,可以将其设置为字符串文字的几个值之一。 char *myStrLiteral = NULL; ... if(blah) myS
对于以下数据 - let $x := "Yahooooo !!!! Select one number - " let $y := 1 2 3 4 5 6 7 我想得到
我正在看 UDEMY for perl 的培训视频,但是视频不清晰,看起来有错误。 培训展示了如何使用以下示例连接 2 个字符串: #!usr/bin/perl print $str = "Hi";
我是一名优秀的程序员,十分优秀!