2

unknown host当我尝试在此处启动 RMI 服务器时出现错误。错误是unknown host。实际上,我只是 RMI 和 JAVA 套接字编程的初学者。您能否为我提供一些 有关我的问题的教程。

我的界面代码:

package ApplicationServer;    
import java.io.File;
import java.rmi.RemoteException;
import java.sql.ResultSet;

public interface Méthodes {

    public String authentification(String login, String mdp) throws RemoteException;
    public ResultSet selection(String requete) throws RemoteException;
    public int miseAjour(String requete) throws RemoteException;
    public String envoyerFichier(File fichier) throws RemoteException;
}

在这门课中,我拥有程序中需要的所有方法:

package ApplicationServer;
import java.io.File;
import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class Traitements extends UnicastRemoteObject implements Méthodes {

    private Connection cnx;
    private Statement stm;
    private ResultSet rst;
    private int rs;

    public void setCnx(Connection cnx) {
        this.cnx = cnx;
    }

    public void setStm(Statement stm) {
        this.stm = stm;
    }

    public void setRst(ResultSet rst) {
        this.rst = rst;
    }

    public void setRs(int rs) {
        this.rs = rs;
    }

    protected Traitements() throws RemoteException {
        super();
        // TODO Auto-generated constructor stub
    }

    @Override
    public String authentification(String login, String mdp) throws RemoteException {
        // TODO Auto-generated method stub
        try {

            setCnx(null);
            setStm(null);
            setRst(null);

            Class.forName("com.mysql.jdbc.Driver"); 
            cnx=DriverManager.getConnection("jdbc:mysql://localhost:3306/banque","root","");
            stm=cnx.createStatement();

            rst=stm.executeQuery("select md5('"+mdp+"');");
            while(rst.next()){
                mdp=rst.getString(1);
            }

            stm.clearBatch();
            stm=cnx.createStatement();
            setRst(null);
            String Query = "select * from utilisateurs where login like '"+login+"' and motdepasse like '"+mdp+"';"; 
            rst=stm.executeQuery(Query);

            int id = 0;
            String nm = null;
            String prm = null;

            while(rst.next()){
                id = rst.getInt("id");
                nm = rst.getString("nom");
                prm = rst.getString("prenom");  
            }
            if(id>0 && nm!=null && prm!=null){
                return id+" "+nm+" "+prm;   
            }
        }catch (SQLException | ClassNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }  
        return null;
    }

    @Override
    public ResultSet selection(String requete) throws RemoteException {
        try{
            setCnx(null);
            setStm(null);
            setRst(null);

            Class.forName("com.mysql.jdbc.Driver"); 
            cnx=DriverManager.getConnection("jdbc:mysql://localhost:3306/banque","root","");
            stm=cnx.createStatement(); 
            rst=stm.executeQuery(requete);

        }catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }   
        catch (ClassNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return rst;
    }

    @Override
    public int miseAjour(String requete) throws RemoteException {
        try{
            setCnx(null);
            setStm(null);
            setRs(0);

            Class.forName("com.mysql.jdbc.Driver"); 
            cnx=DriverManager.getConnection("jdbc:mysql://localhost:3306/banque","root","");
            stm=cnx.createStatement(); 
            rs=stm.executeUpdate(requete);

        }catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }   
        catch (ClassNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return rs;
    }
    @Override
    public String envoyerFichier(File fichier) throws RemoteException {
        // TODO Auto-generated method stub
        return null;
    }

}

这是运行服务器的主类:

package ApplicationServer;

import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;
import javax.swing.JOptionPane;

public class Main {
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        try {
            int port=12345;
            String url="rmi://serveur:"+port+"/reference";      
            LocateRegistry.createRegistry(port);
            Traitements srv = new Traitements();
            Naming.rebind(url, srv);

            JOptionPane.showMessageDialog(null, "Serveur Lance :");

        } catch (RemoteException | MalformedURLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    } 
}
4

1 回答 1

1

您应该serveur用该代码中的真实主机名替换。

localhost但是,绑定时在 RMI URL中使用要好得多。无论如何,注册表必须是主机本地的,因此使用其他任何东西都没有意义。

于 2016-02-28T00:24:49.470 回答