0

您好我正在尝试通过 ssh 隧道连接到服务器上的数据库,但我什至无法连接 Jsch 会话。我试图在 GWT 中将其作为后端代码的一部分。所以这是在服务器端代码的实现部分。我一般对服务器不是很熟悉。通常在终端 I 中键入:

ssh -x 用户名@xxxxx.xxx.edu

然后我被提示输入我的密码,我输入密码,然后我就进去了。

所以在java中我的代码如下:

String host="xxxxx.xxx.edu";

String user="username";
String password="password";

Session session= null;
try{
            //Set StrictHostKeyChecking property to no to avoid UnknownHostKey issue
            java.util.Properties config = new java.util.Properties();
            config.put("StrictHostKeyChecking", "no");
            JSch jsch = new JSch();
            session=jsch.getSession(user, host, 22);
            session.setPassword(password);
            session.setConfig(config);
            session.connect();
}

我已经仔细检查了用户名和密码以及主机字符串,它们都是我在终端中成功使用的。

我在“session.connect()”行得到的错误如下:(向右滚动查看整个错误)

com.jcraft.jsch.JSchException: java.security.AccessControlException: access denied (java.net.SocketPermission xxxxx.xxx.edu resolve)
at com.jcraft.jsch.Util.createSocket(Util.java:341)
at com.jcraft.jsch.Session.connect(Session.java:194)
at com.jcraft.jsch.Session.connect(Session.java:162)
at com.front.server.GameServiceImpl.createGame(GameServiceImpl.java:39)

有什么我想念的吗?这与我在终端中通过 ssh 登录所做的不同吗?我也尝试在主机字符串前添加 'ssh://',但无济于事。

提前致谢!

4

2 回答 2

1

我发现上面的代码没有问题。我将它复制/粘贴到一个简单的 java main 中,它工作正常。将相同的代码放在 GWT 后端似乎有问题。

于 2012-05-12T16:50:22.907 回答
0

根据异常信息,问题似乎不是来自JSch。

请参阅java.sun.com 上的安全和权限:

除了对调用程序的目录及其子目录的读取访问权限之外,所有使用安全管理器调用的小程序和任何应用程序都必须被授予访问本地系统资源的显式权限。Java 平台提供权限以允许对不同类型的本地信息进行不同级别的访问。

,并参见SocketPermission部分。

于 2012-05-12T23:25:53.823 回答