cari
RumahJavajavaTutorialBagaimana untuk menggunakan simulasi Java untuk mencapai penembusan intranet ke dalam kotak hitam?

1. Pengenalan kepada penembusan intranet

Pemahaman dari perspektif kotak hitam: Biasanya, sama ada komputer peribadi disambungkan ke WIFI atau kabel rangkaian, ia adalah milik bahagian dalam LAN, dan luaran Internet tidak boleh mengakses komputer anda secara terus Penembusan intranet boleh membenarkan komputer dalam LAN anda mengakses rangkaian luaran. Berikan contoh: Jika anda menjalankan perkhidmatan web secara setempat dan port yang diduduki ialah 8080, maka ujian tempatan anda ialah: //localhost:8080. Tetapi bagaimana jika anda ingin berkongsi perkhidmatan anda dengan rakan baik? Ya, ia adalah melalui penembusan intranet. Sebenarnya, penembusan intranet adalah operasi yang sangat rumit Penjelasan pada Ensiklopedia Baidu ialah:

Penembusan intranet, iaitu penembusan NAT dilakukan untuk membolehkan paket data A tertentu dengan sumber tertentu Alamat IP dan nombor port sumber tidak disekat oleh peranti NAT dan dihalakan dengan betul ke hos intranet.

Saya jelas tidak boleh melakukannya di sini. Apa yang saya perlukan adalah perkhidmatan untuk mengakses intranet dari rangkaian luaran Bagi proses tertentu, saya tidak peduli, saya hanya perlu mencapai matlamat ini.

2. Idea khusus dan butiran pelaksanaan

2.1 Idea khusus

Tidak kira kaedah yang digunakan untuk mencapai penembusan intranet, alamat IP awam diperlukan Pelayan Alibaba Cloud digunakan. Berikut ialah gambarajah skematik keseluruhan simulasi:

Bagaimana untuk menggunakan simulasi Java untuk mencapai penembusan intranet ke dalam kotak hitam?

Nota:

1 Pelayan penembusan intranet digunakan pada mesin dengan IP awam.

2. Perkhidmatan intranet dan pelanggan penembusan intranet digunakan pada mesin intranet.

Penjelasan:

Idea saya sangat mudah, iaitu pengguna mengakses pelayan penembusan intranet, dan kemudian pelayan penembusan intranet menghantar permintaan pengguna mesej memajukannya ke klien penembusan intranet , dan kemudian klien penembusan intranet memajukan mesej permintaan ke perkhidmatan intranet , dan kemudian menerima perkhidmatan intranet Mesej respons dimajukan ke pelayan penembusan intranet, dan akhirnya pelayan penembusan intranet memajukannya kepada pengguna. Proses umum adalah seperti berikut Untuk pengguna luaran, ia hanya akan berfikir bahawa mereka telah mengakses perkhidmatan rangkaian luaran, kerana pengguna menghadapi sistem kotak hitam.

2.2 Butiran pelaksanaan

Untuk mencapai matlamat di atas, perkara yang paling kritikal ialah mengekalkan sambungan panjang antara klien penembusan intranet dan pelayan penembusan intranet, saya perlu menggunakan sambungan yang panjang ini untuk bertukar maklumat mesej antara kedua-dua pihak. Oleh itu, sambungan panjang ini perlu diwujudkan selepas sistem dimulakan Apabila permintaan pengguna masuk, pelayan penembusan intranet mula-mula menerima permintaan itu, dan kemudian menggunakan sambungan panjang untuk memindahkannya ke klien penembusan rangkaian menggunakan mesej ini sebagai permintaan untuk mengakses perkhidmatan intranet, kemudian menerima respons daripada perkhidmatan intranet, memajukannya ke pelayan penembusan intranet, dan akhirnya memajukannya kepada pengguna.

3. Pelaksanaan kod

3.1 Struktur direktori

Bagaimana untuk menggunakan simulasi Java untuk mencapai penembusan intranet ke dalam kotak hitam?

Penjelasan: Ini adalah kod pelayan dan pelanggan untuk penembusan intranet bersama-sama dan bukannya menulisnya secara berasingan, kerana kedua-dua pihak perlu menggunakan beberapa kelas biasa. Walau bagaimanapun, adalah disyorkan untuk memisahkannya kepada dua projek kerana ia perlu digunakan secara berasingan. Atau apabila mengeksport ke dalam pakej balang, pilih sahaja kelas utama yang berbeza.

Fail kod pelanggan: Client.java, Connection.java, Msg.java, ProxyConnection.java.
Fail kod sisi pelayan: Server.java, Connection.java, Msg.java, ProxyConnection.java.

3.2 Kelas pelanggan

package org.dragon;
import java.io.IOException;
import java.net.Socket;
import java.net.UnknownHostException;
/**
 * 用于双向通信的客户端
 * */
public class Client {
	private static final String REMOTE_HOST = "公网IP";
	private static final String LOCAL_HOST = "127.0.0.1";
	public static void main(String[] args) {
		try {
			Socket proxy = new Socket(REMOTE_HOST, 10000);       
			System.out.println("Connect Server Successfully!");
			ProxyConnection proxyConnection = new ProxyConnection(proxy);  // 维持和内网穿透服务端的长连接
			// 可以实现同一个人多次访问
			while (true) {
				Msg msg = proxyConnection.receiveMsg();
				Connection connection = new Connection(new Socket(LOCAL_HOST, 8080));
				connection.sendMsg(msg);    // 将请求报文发送给内网服务器,即模拟发送请求报文
				msg = connection.receiveMsg();  // 接收内网服务器的响应报文
				proxyConnection.sendMsg(msg);  // 将内网服务器的响应报文转发给公网服务器(内网穿透服务端)
			}
		} catch (UnknownHostException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}
	}
}

3.3 Kelas sambungan

package org.dragon;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.Socket;
/**
 * 维持用户和服务器的连接
 * */
public class Connection {
	private InputStream input;
	private OutputStream output;
	public Connection(Socket client) throws IOException {
		this.input = new BufferedInputStream(client.getInputStream());
		this.output = new BufferedOutputStream(client.getOutputStream());
	}
	public Msg receiveMsg() throws IOException {
		byte[] msg = new byte[2*1024];
		int len = input.read(msg);
		return new Msg(len, msg);
	}
	public void sendMsg(Msg msg) throws IOException {
		output.write(msg.getMsg(), 0, msg.getLen());
		output.flush();  // 每一次写入都要刷新,防止阻塞。
	}
}

3.4 Kelas msg

package org.dragon;
public class Msg {
	private int len;
	private byte[] msg;
	public Msg(int len, byte[] msg) {
		this.len = len;
		this.msg = msg;
	}
	public int getLen() {
		return len;
	}
	public byte[] getMsg() {
		return msg;
	}
	@Override
	public String toString() {
		return "msg: " + len + " --> " + new String(msg, 0, len);
	}
}

3.5 Kelas ProxyConnection

package org.dragon;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.IOException;
import java.net.Socket;
import java.net.UnknownHostException;
/**
 * @author Alfred
 * 
 * 代理服务器和代理客户端是用于维持两者之间通信的一个长连接Socket,
 * 主要的目的是因为双方之间的通信方式是全双工的,它们的作用是为了传递报文。
 * */
public class ProxyConnection {
	private Socket proxySocket;
	private DataInputStream input;
	private DataOutputStream output;
	public ProxyConnection(final Socket socket) throws UnknownHostException, IOException {
		proxySocket = socket;
		input = new DataInputStream(new BufferedInputStream(proxySocket.getInputStream()));
		output = new DataOutputStream(new BufferedOutputStream(proxySocket.getOutputStream()));
	}
	/**
	 * 接收报文
	 * @throws IOException 
	 * */
	public Msg receiveMsg() throws IOException {
		int len = input.readInt();
		if (len <= 0) {
			throw new IOException("异常接收数据,长度为:" + len);
		}
		byte[] msg = new byte[len];
		int size = input.read(msg);  // 这里到底会不会读取到这么多,我也有点迷惑!
		return new Msg(size, msg);   // 为了防止出错,还是使用一个记录实际读取值size
	}
	/**
	 * 转发报文
	 * @throws IOException 
	 * */
	public void sendMsg(Msg msg) throws IOException {
		output.writeInt(msg.getLen());
		output.write(msg.getMsg(), 0, msg.getLen());
		output.flush();  // 每一次写入都需要手动刷新,防止阻塞。
	}
}

3.4 Kelas msg

package org.dragon;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
/**
 * 用于双向通信的服务器
 * */
public class Server {
	public static void main(String[] args) {
		try (ServerSocket server = new ServerSocket(10000)) {
			// 用于交换控制信息的Socket
			Socket proxy = server.accept();
			ProxyConnection proxySocket = new ProxyConnection(proxy);
			// 用于正常通讯的socket
			while (true) {
				Socket client = server.accept();
				Connection connection = new Connection(client);
				Msg msg = connection.receiveMsg();  // 接收用户的请求报文
				proxySocket.sendMsg(msg);           // 转发用户的请求报文给内网服务器
				msg = proxySocket.receiveMsg();     // 接收内网服务器的响应报文
				connection.sendMsg(msg);            // 转发内网服务器的响应报文给用户
			}
		} catch (IOException e) {
			e.printStackTrace();
		}
	}
}

3.5 Kelas ProxyConnection

rreee

3.6 Server 🎜>
package org.dragon.controller;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class Controller {
	@GetMapping("/loveEN")
	public String testEN() {
		return "I love you yesterday and today!";
	}
	@GetMapping("/loveZH") 
	public String loveZH() {
		return "有一美人兮,见之不忘。一日不见兮,思之如狂。凤飞翱翔兮,四海求凰。无奈佳人兮,不在东墙。";
	}
	@GetMapping("/loveJson")
	public Map<String, String> loveJson() {
		HashMap<String, String> map = new LinkedHashMap<>();
		map.put("english", "I love you yesterday and today!");
		map.put("chinese", "有一美人兮,见之不忘。一日不见兮,思之如狂。"
				+ "凤飞翱翔兮,四海求凰。无奈佳人兮,不在东墙。");
		return map;
	}
}

4. Perkhidmatan Intranet

Perkhidmatan intranet ialah perkhidmatan web Di sini saya menggunakan projek SpringBoot yang mudah, yang hanya mempunyai tiga kaedah permintaan.

rrreee

5. Ujian

5.1 Ujian intranetBagaimana untuk menggunakan simulasi Java untuk mencapai penembusan intranet ke dalam kotak hitam?Bagaimana untuk menggunakan simulasi Java untuk mencapai penembusan intranet ke dalam kotak hitam?Mulakan perkhidmatan intranet dan masukkan tiga URL berikut dalam pelayar untuk menguji.

Bagaimana untuk menggunakan simulasi Java untuk mencapai penembusan intranet ke dalam kotak hitam?

5.2 Ujian rangkaian luaran

Mulakan pelayan penembusan rangkaian dalaman dan klien penembusan rangkaian dalaman, dan kemudian akses tiga URL dalam penyemak imbas. Nota: 1. Jika anda mengujinya sendiri, anda boleh bertukar kepada alamat IP pelayan penembusan intranet yang anda jalankan atau menggunakan nama domain. 2. Mesin rangkaian luaran dan mesin rangkaian dalaman di sini menggunakan port yang berbeza (gunakan secara santai, selagi ia tidak bercanggah dengan port perkhidmatan pada mesin anda sendiri, anda boleh menggunakan port 80 pada rangkaian luaran,). yang lebih mesra pengguna biasa . 3. Ujian ketiga sebenarnya gagal Anda boleh melihat animasi pemuatan di atas, yang terus dimuatkan. Memang masuk akal bahawa ini harus dihentikan tidak lama lagi, tetapi nampaknya mustahil untuk dihentikan. Ini adalah pepijat sistem, tetapi disebabkan pengetahuan saya yang terhad, saya tidak akan menyelesaikannya.

Bagaimana untuk menggunakan simulasi Java untuk mencapai penembusan intranet ke dalam kotak hitam?

Bagaimana untuk menggunakan simulasi Java untuk mencapai penembusan intranet ke dalam kotak hitam?

Bagaimana untuk menggunakan simulasi Java untuk mencapai penembusan intranet ke dalam kotak hitam?

6. Nota

Kod di sini ialah A simulasi, ia hanya boleh mensimulasikan fungsi ini, tetapi pada dasarnya tidak mempunyai kesan sebenar, haha. Oleh kerana saya hanya mempunyai satu sambungan yang panjang di sini, saya hanya boleh menyokong komunikasi bersiri Adalah lebih baik untuk memanggilnya oleh satu orang Nampaknya kelajuan panggilan tidak boleh terlalu cepat. Saya memikirkan cara untuk mengekalkan kumpulan sambungan antara pelanggan dan pelayan, supaya akses berbilang benang boleh dicapai. Tiada pemprosesan pelekatan paket TCP dan pengepakan di sini (saya faham konsep ini, tetapi saya tidak begitu mahir mengendalikannya), jadi saya lalai untuk meminta dan membalas mesej dalam saiz 2KB. Melebihi panjang ini akan menyebabkan masalah Walaupun parameter ini boleh ditingkatkan, jika kebanyakan paket adalah sangat kecil, ia juga akan membawa kepada kecekapan yang rendah. Penembusan intranet ini boleh menyokong pelbagai protokol di atas TCP, tidak semestinya HTTP, sekurang-kurangnya secara teori adalah mungkin.

Atas ialah kandungan terperinci Bagaimana untuk menggunakan simulasi Java untuk mencapai penembusan intranet ke dalam kotak hitam?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Artikel ini dikembalikan pada:亿速云. Jika ada pelanggaran, sila hubungi admin@php.cn Padam
Bagaimanakah saya menggunakan Maven atau Gradle untuk Pengurusan Projek Java Lanjutan, Membina Automasi, dan Resolusi Ketergantungan?Bagaimanakah saya menggunakan Maven atau Gradle untuk Pengurusan Projek Java Lanjutan, Membina Automasi, dan Resolusi Ketergantungan?Mar 17, 2025 pm 05:46 PM

Artikel ini membincangkan menggunakan Maven dan Gradle untuk Pengurusan Projek Java, membina automasi, dan resolusi pergantungan, membandingkan pendekatan dan strategi pengoptimuman mereka.

Bagaimanakah saya membuat dan menggunakan perpustakaan Java Custom (fail JAR) dengan pengurusan versi dan pergantungan yang betul?Bagaimanakah saya membuat dan menggunakan perpustakaan Java Custom (fail JAR) dengan pengurusan versi dan pergantungan yang betul?Mar 17, 2025 pm 05:45 PM

Artikel ini membincangkan membuat dan menggunakan perpustakaan Java tersuai (fail balang) dengan pengurusan versi dan pergantungan yang betul, menggunakan alat seperti Maven dan Gradle.

Bagaimanakah saya melaksanakan caching pelbagai peringkat dalam aplikasi java menggunakan perpustakaan seperti kafein atau cache jambu?Bagaimanakah saya melaksanakan caching pelbagai peringkat dalam aplikasi java menggunakan perpustakaan seperti kafein atau cache jambu?Mar 17, 2025 pm 05:44 PM

Artikel ini membincangkan pelaksanaan caching pelbagai peringkat di Java menggunakan kafein dan cache jambu untuk meningkatkan prestasi aplikasi. Ia meliputi persediaan, integrasi, dan faedah prestasi, bersama -sama dengan Pengurusan Dasar Konfigurasi dan Pengusiran PRA Terbaik

Bagaimanakah saya boleh menggunakan JPA (Java Constence API) untuk pemetaan objek-objek dengan ciri-ciri canggih seperti caching dan malas malas?Bagaimanakah saya boleh menggunakan JPA (Java Constence API) untuk pemetaan objek-objek dengan ciri-ciri canggih seperti caching dan malas malas?Mar 17, 2025 pm 05:43 PM

Artikel ini membincangkan menggunakan JPA untuk pemetaan objek-relasi dengan ciri-ciri canggih seperti caching dan pemuatan malas. Ia meliputi persediaan, pemetaan entiti, dan amalan terbaik untuk mengoptimumkan prestasi sambil menonjolkan potensi perangkap. [159 aksara]

Bagaimanakah mekanisme kelas muatan Java berfungsi, termasuk kelas yang berbeza dan model delegasi mereka?Bagaimanakah mekanisme kelas muatan Java berfungsi, termasuk kelas yang berbeza dan model delegasi mereka?Mar 17, 2025 pm 05:35 PM

Kelas kelas Java melibatkan pemuatan, menghubungkan, dan memulakan kelas menggunakan sistem hierarki dengan bootstrap, lanjutan, dan pemuat kelas aplikasi. Model delegasi induk memastikan kelas teras dimuatkan dahulu, yang mempengaruhi LOA kelas tersuai

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

Versi Mac WebStorm

Versi Mac WebStorm

Alat pembangunan JavaScript yang berguna

mPDF

mPDF

mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

VSCode Windows 64-bit Muat Turun

VSCode Windows 64-bit Muat Turun

Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini