有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

从另一台PC(从java应用程序)连接到MySQL服务器

我实现了一个连接到MySQL的java应用程序

当我在同一本地网络的另一台pc的导航器中设置我的pc的ip地址时,我可以访问phpMyadmin和Wamp

当我在同一台pc上安装127.0.0.1(Wamp安装)时,我从java应用程序连接到127.0.0.1,它就工作了

但是,当我将ip地址从我的pc或同一本地网络中的另一台pc放入java应用程序时,我无法连接

这是我在java应用程序中的配置文件:

db.user=root
db.password=
db.driver=com.mysql.jdbc.Driver
db.url=jdbc:mysql://192.168.1.59:3306/testfournisseur

有什么需要操纵的吗

这是连接到数据库时出现的错误:

Caused by: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException:   Communications link failure

Last packet sent to the server was 1 ms ago.
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
at java.lang.reflect.Constructor.newInstance(Unknown Source)
at com.mysql.jdbc.Util.handleNewInstance(Util.java:406)
at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:1074)
at com.mysql.jdbc.MysqlIO.readPacket(MysqlIO.java:666)
at com.mysql.jdbc.MysqlIO.doHandshake(MysqlIO.java:1069)
at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2031)
... 72 more
Caused by: java.io.EOFException: Can not read response from server. Expected to read 4 bytes, read 0 bytes before connection was unexpectedly lost.
at com.mysql.jdbc.MysqlIO.readFully(MysqlIO.java:2431)
at com.mysql.jdbc.MysqlIO.readPacket(MysqlIO.java:590)
... 74 more

共 (1) 个答案

  1. # 1 楼答案

    我不熟悉Windows上的MySQL,但我看到的无法连接的最常见原因是my.cnf中的bind-address被设置为127.0.0.1,如果您将其更改为0.0.0.0或其他可访问的地址,那么它应该可以正常工作

    我还注意到您在属性示例中指定了端口80,默认情况下MySQL在3306上运行,因此将端口更改为该端口(或省略该端口)可能有效

    编辑:Windows的内置防火墙可能会阻止连接,因此绝对值得查看