SSH

Aus Programmers Guide

Version vom 13:55, 20. Sep. 2010 bei Roy (Diskussion | Beiträge)
(Unterschied) ← Nächstältere Version | Aktuelle Version (Unterschied) | Nächstjüngere Version → (Unterschied)
Wechseln zu: Navigation, Suche

Inhaltsverzeichnis

Ubuntu

Authentifizierung mit Hilfe von Schlüsseln

ssh-keygen -t rsa
ssh-copy-id -i ~/.ssh/id_rsa.pub user@server


Datei über SSH (SCP) kopieren

siehe: Ubuntu


JAVA

Einen Tunnel Herstellen mit JSch

Hier gehts zu JSch

...
JSch jsch = new JSch();
session = jsch.getSession(<ssh_user>, <ssh_host>, <ssh_port>);
UserInfo ui = new MyUserInfo();
session.setUserInfo(ui);
session.connect();
int assinged_port;
assinged_port = session.setPortForwardingL(<localport>, <tunnelziel>, <port>);
System.out.println("localhost:" +assinged_port+ " -> <tunnelziel>:<tunnelport>");
...
 
 
public static class MyUserInfo implements UserInfo, UIKeyboardInteractive {
	public String getPassword() {
			return passwd;
	}
 
	public boolean promptYesNo(String str) {
		/*
		 * Object[] options={ "yes", "no" }; int
		 * foo=JOptionPane.showOptionDialog(null, str, "Warning",
		 * JOptionPane.DEFAULT_OPTION, JOptionPane.WARNING_MESSAGE, null,
		 * options, options[0]);
		 * 
		 * return foo==0;
		 */
		return true;
 
	}
	String passwd;
	JTextField passwordField = (JTextField) new JPasswordField(20);
 
	public String getPassphrase() {
		return null;
	}
 
	public boolean promptPassphrase(String message) {
		return true;
	}
 
	public boolean promptPassword(String message) {
 
 
		Object[] ob = { passwordField };
		int result = JOptionPane.showConfirmDialog(null, ob, message,
		JOptionPane.OK_CANCEL_OPTION);
		if (result == JOptionPane.OK_OPTION) {
			passwd = passwordField.getText();
 
			return true;
		} else {
			// wenn Abbrechen beim PW-Feld gedrückt beenden wir
			disconnectAndExit();
 
			return false;
		}
	}
 
	public void showMessage(String message) {
		JOptionPane.showMessageDialog(null, message);
	}
 
	final GridBagConstraints gbc = new GridBagConstraints(0, 0, 1, 1, 1, 1,
			GridBagConstraints.NORTHWEST, GridBagConstraints.NONE,
			new Insets(0, 0, 0, 0), 0, 0);
	private Container panel;
 
	public String[] promptKeyboardInteractive(String destination,
			String name, String instruction, String[] prompt, boolean[] echo) {
		panel = new JPanel();
		panel.setLayout(new GridBagLayout());
 
		gbc.weightx = 1.0;
		gbc.gridwidth = GridBagConstraints.REMAINDER;
		gbc.gridx = 0;
		panel.add(new JLabel(instruction), gbc);
		gbc.gridy++;
 
		gbc.gridwidth = GridBagConstraints.RELATIVE;
 
		JTextField[] texts = new JTextField[prompt.length];
		for (int i = 0; i < prompt.length; i++) {
			gbc.fill = GridBagConstraints.NONE;
			gbc.gridx = 0;
			gbc.weightx = 1;
			panel.add(new JLabel(prompt[i]), gbc);
 
			gbc.gridx = 1;
			gbc.fill = GridBagConstraints.HORIZONTAL;
			gbc.weighty = 1;
			if (echo[i]) {
				texts[i] = new JTextField(20);
			} else {
				texts[i] = new JPasswordField(20);
			}
			panel.add(texts[i], gbc);
			gbc.gridy++;
		}
 
		if (JOptionPane.showConfirmDialog(null, panel, destination + ": "
				+ name, JOptionPane.OK_CANCEL_OPTION,
				JOptionPane.QUESTION_MESSAGE) == JOptionPane.OK_OPTION) {
			String[] response = new String[prompt.length];
			for (int i = 0; i < prompt.length; i++) {
				response[i] = texts[i].getText();
			}
			return response;
		} else {
			return null; // cancel
		}
	}
}

Putty und das Public-Key verfahren

Mit Hilfe des Public-Key verfahrens aus Putty auf einem Server anmelden:

#Schlüsselpaar erzeugen
ssh-keygen -t dsa
cat .ssh/id_dsa.pub >> .ssh/authorized_keys
  • Tranferieren des Schlüssels (id_dsa) zum Putty-System mit SFTP o.ä.
  • Download PuttyGen http://www.chiark.greenend.org.uk/~sgtatham/putty/download.html
  • Starten von PuttyGen Load Klicken und unten "all files" wählen id_dsa öffnen
  • Save private key
  • OK
  • Start Putty
  • Navigiere zu SSH->Auth
  • Die erzeugte ppk Datei einfügen
  • Speichen auf der Hauptseite
  • Verbinung Öffnen
Persönliche Werkzeuge