Bonjour, je tente de lancer une capture de trafic en utilisant tcpdump sous linux, mais j'ai un probleme pour l'exécution des commandes , voici ma classe Java qui me permet de se connecter à un serveur en ssh, et de lancer une commande :
avec la classe sshcmd
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26 package marouene; import java.io.IOException; import com.jcraft.jsch.JSchException; import com.jcraft.jsch.Session; public class transfert { static sshcmd sesserver = new sshcmd(); static sshcmd sesserver1 = new sshcmd(); static sshcmd sesclient = new sshcmd(); static sshcmd sesclient1 = new sshcmd(); public static void main (String[] args) throws JSchException, IOException { Session s1 = sesserver.ss("10.88.2.5"); Session s11 = sesserver1.ss("10.88.2.5"); Session s2 = sesclient.ss("10.88.55.2"); sesserver.exec(s1,"tcpdump -i eth0 -s 200 -w /home/raceserver.pcap"); sesclient.exec(s2,"tcpdump -i eth1 -s 200 -w /home/traceclient.pcap"); sesserver1.exec(s11,"wget 10.88.2.5/fich"); Thread.sleep(90000); sesclient.exec(s22,"kill tcpdpid"); sesserver.exec(s111,"kill tcpdpid"); } }
le but est de se connecter sur une machine , de lancer un téléchargement en http, puis de faire une capture du trafic au niveau de la machine et au niveau du serveur de téléchargement
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54 package marouene; import com.jcraft.jsch.*; import java.awt.*; import java.io.IOException; import java.io.InputStream; import javax.swing.*; public class sshcmd{ public Session ss(String addresse) throws JSchException{ JSch jsch=new JSch(); jsch.setKnownHosts("~/.ssh/known_hosts"); Session session=jsch.getSession("root", addresse, 22); session.setPassword("qsdqsdqs"); session.setConfig("StrictHostKeyChecking", "no"); //session.connect(); session.connect(30000); // making a connection with timeout. return session; } public void exec(Session s,String c) throws JSchException, IOException{ Channel channel=s.openChannel("exec"); ((ChannelExec)channel).setCommand(c); ((ChannelExec)channel).setErrStream(System.err); InputStream in=channel.getInputStream(); channel.connect(); byte[] tmp=new byte[1024]; while(true){ while(in.available()>0){ int i=in.read(tmp, 0, 1024); if(i<0)break; System.out.print(new String(tmp, 0, i)); } if(channel.isClosed()){ break; } try{Thread.sleep(1000);}catch(Exception ee){} } channel.disconnect(); s.disconnect(); } }
Sauf que la, j'ai un problème , car quand je lance le téléchargement , si je met par la suite une commande qui arrete tcpdump, j'aurai un arret de la capture avant meme la fin du téléchargement...j'ai ajouter un thread pour faire une pause, mais bon ca ne garantie rien
Partager