Navicat使用HTTP通道远程连接SQLite

在线上环境的服务器,一般都是关闭了数据库外网访问的权限,这时候外网就不能直接连接数据库了,需要在服务器内才能操作数据库。但Navicat软件提供了HTTP通道代理连接数据库功能,只要服务器上有HTTP服务,并且端口开放了,就可以使用HTTP通道来连接数据库。

基本原理

数据库端口没开放外网访问的时候,Navicat在外网无法访问数据库。

服务器上运行着PHP,并且我们是可以访问到PHP的。

PHP可以连接SQLite数据库并执行SQL语句,因为它们都在内网和PHP支持SQLite。

虽然Navicat无法连接上SQLite,但是Navicat对数据库所有的查询可以让PHP代为查询,然后把结果返回给Navicat。

所以把一个php脚本放到服务器上,就可以让Navicat间接连接数据库,对数据库进行操作了。

上传PHP脚本

Navicat软件自带三个php代理脚本,它在Navicat安装目录下,分别是:ntunnel_sqlite.php ntunnel_pgsql.php ntunnel_sqlite.php 点击获取

这里主要讲SQLite,所以用到的是ntunnel_sqlite.php脚本,其他数据库基本同理。

ntunnel_sqlite.php上传到服务器(远程服务器必须支持php环境),并测试能否通过浏览器访问到

在新建或者编辑连接的时候,选项卡里面都会有一个HTTP,切换到HTTP选项卡。

然后勾选使用HTTP通道通道网址处输入ntunnel_sqlite.php的网址。

建议勾选上用base64编码传出查询,不然有可能出现700 Invalid response: 500错误。

这个错误主要出现在获取数据库列表和表结构的时候出现,服务器有使用防护软件,也有可能是它捣的鬼。

然后在常规选项卡里,设置好端口用户名密码,主机输入127.0.0.1或者对应的内网IP。

简单来说就是服务器上项目配置里的数据库连接配置怎么设置的,这里就怎么设置,因为是用php来代替连接数据库

测试连接

最后,测试下连接。如果有错误,先重启navicate,还不行的话再按照错误信息修改下对应的配置即可。

附件

如果你不知道在哪找到通道脚本,关注下面微信号,回复 navicat 即可获取。

关注作者公众号,获取更多资源!
赏作者一杯咖啡~