이 글에서는 주로 JAVA가 클라이언트 IP 주소와 MAC 주소를 얻는 방법을 소개하는데, 이는 매우 실용적입니다. 자세한 코드는 여기에 정리되어 있습니다. 도움이 필요한 친구는 이를 참조할 수 있습니다.
이 글은 JAVA가 클라이언트 IP 주소와 MAC 주소를 얻는 방법을 소개합니다. . , 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.
1. 클라이언트 IP 주소를 가져옵니다.
public String getIp(HttpServletRequest request) throws Exception { String ip = request.getHeader("X-Forwarded-For"); if (ip != null) { if (!ip.isEmpty() && !"unKnown".equalsIgnoreCase(ip)) { int index = ip.indexOf(","); if (index != -1) { return ip.substring(0, index); } else { return ip; } } } ip = request.getHeader("X-Real-IP"); if (ip != null) { if (!ip.isEmpty() && !"unKnown".equalsIgnoreCase(ip)) { return ip; } } return request.getRemoteAddr(); }
대신 request.getRemoteAddr()을 직접 사용하지 마세요. Forwarded-For" 및 "X-Real-IP"
X-Forwarded-For: client1,proxy1,proxy2,proxy3
값은 쉼표 + 공백으로 구분됩니다. 가장 왼쪽(client1)이 가장 IP 주소입니다. 프록시 서버는 요청을 성공적으로 수신할 때마다 요청 소스 IP 주소를 오른쪽에 추가합니다.
첫 번째 IP 주소만 가져옵니다
X-Real-IP. 일반적으로 실제로 요청한 클라이언트 IP만 기록됩니다.
localhost를 사용하여 IP 주소에 액세스하는 문제를 해결하려면 0:0입니다. :0:0:0:0:0 :1 질문
public String getIp(HttpServletRequest request) throws Exception { String ip = request.getHeader("X-Forwarded-For"); if (ip != null) { if (!ip.isEmpty() && !"unKnown".equalsIgnoreCase(ip)) { int index = ip.indexOf(","); if (index != -1) { return ip.substring(0, index); } else { return ip; } } } ip = request.getHeader("X-Real-IP"); if (ip != null) { if (!ip.isEmpty() && !"unKnown".equalsIgnoreCase(ip)) { return ip; } } ip = request.getHeader("Proxy-Client-IP"); if (ip != null) { if (!ip.isEmpty() && !"unKnown".equalsIgnoreCase(ip)) { return ip; } } ip = request.getHeader("WL-Proxy-Client-IP"); if (ip != null) { if (!ip.isEmpty() && !"unKnown".equalsIgnoreCase(ip)) { return ip; } } ip = request.getRemoteAddr(); return ip.equals("0:0:0:0:0:0:0:1") ? "127.0.0.1" : ip; }
2. 클라이언트 MAC 주소 가져오기
UdpGetClientMacAddr umac = new UdpGetClientMacAddr(sip); String smac = umac.GetRemoteMacAddr();
MAC 가져오기 시간 제한 추가
final UdpGetClientMacAddr umac = new UdpGetClientMacAddr(sip); //---长时间获取不到MAC地址则放弃 ExecutorService exec = Executors.newFixedThreadPool(1); Callable<String> call = new Callable<String>() { public String call() throws Exception { return umac.GetRemoteMacAddr(); } }; try { Future<String> future = exec.submit(call); String smac = future.get(1000 * 1, TimeUnit.MILLISECONDS); loginMonitor.setMacAddress(smac); } catch (TimeoutException ex) { loginMonitor.setMacAddress("获取失败"); logger.info("获取MAC地址超时"); ex.printStackTrace(); } // 关闭线程池 exec.shutdown(); //---
필요합니다. UdpGetClientMacAddr
UdpGetClientMacAddr.java
package shmc.commonsys.security.controller; import java.io.IOException; import java.net.DatagramPacket; import java.net.DatagramSocket; import java.net.InetAddress; /** * 主机A向主机B发送“UDP-NetBIOS-NS”询问包,即向主机B的137端口,发Query包来询问主机B的NetBIOS Names信息。 * 其次,主机B接收到“UDP-NetBIOS-NS”询问包,假设主机B正确安装了NetBIOS服务........... 而且137端口开放,则主机B会向主机A发送一个“UDP-NetBIOS-NS”应答包,即发Answer包给主机A。 * 并利用UDP(NetBIOS Name Service)来快速获取远程主机MAC地址的方法 * */ public class UdpGetClientMacAddr { private String sRemoteAddr; private int iRemotePort=137; private byte[] buffer = new byte[1024]; private DatagramSocket ds=null; public UdpGetClientMacAddr(String strAddr) throws Exception{ sRemoteAddr = strAddr; ds = new DatagramSocket(); } public final DatagramPacket send(final byte[] bytes) throws IOException { DatagramPacket dp = new DatagramPacket(bytes,bytes.length,InetAddress.getByName(sRemoteAddr),iRemotePort); ds.send(dp); return dp; } public final DatagramPacket receive() throws Exception { DatagramPacket dp = new DatagramPacket(buffer,buffer.length); ds.receive(dp); return dp; } public byte[] GetQueryCmd() throws Exception { byte[] t_ns = new byte[50]; t_ns[0] = 0x00; t_ns[1] = 0x00; t_ns[2] = 0x00; t_ns[3] = 0x10; t_ns[4] = 0x00; t_ns[5] = 0x01; t_ns[6] = 0x00; t_ns[7] = 0x00; t_ns[8] = 0x00; t_ns[9] = 0x00; t_ns[10] = 0x00; t_ns[11] = 0x00; t_ns[12] = 0x20; t_ns[13] = 0x43; t_ns[14] = 0x4B; for(int i = 15; i < 45; i++){ t_ns[i] = 0x41; } t_ns[45] = 0x00; t_ns[46] = 0x00; t_ns[47] = 0x21; t_ns[48] = 0x00; t_ns[49] = 0x01; return t_ns; } public final String GetMacAddr(byte[] brevdata) throws Exception { // 获取计算机名 int i = brevdata[56] * 18 + 56; String sAddr=""; StringBuffer sb = new StringBuffer(17); // 先从第56字节位置,读出Number Of Names(NetBIOS名字的个数,其中每个NetBIOS Names Info部分占18个字节) // 然后可计算出“Unit ID”字段的位置=56+Number Of Names×18,最后从该位置起连续读取6个字节,就是目的主机的MAC地址。 for(int j = 1; j < 7;j++) { sAddr = Integer.toHexString(0xFF & brevdata[i+j]); if(sAddr.length() < 2) { sb.append(0); } sb.append(sAddr.toUpperCase()); if(j < 6) sb.append(':'); } return sb.toString(); } public final void close() throws Exception { ds.close(); } public final String GetRemoteMacAddr() throws Exception { byte[] bqcmd = GetQueryCmd(); send(bqcmd); DatagramPacket dp = receive(); String smac = GetMacAddr(dp.getData()); close(); return smac; } public static void main(String args[]) throws Exception{ UdpGetClientMacAddr umac=new UdpGetClientMacAddr("172.19.1.198"); umac=new UdpGetClientMacAddr("192.168.16.83"); System.out.println(umac.GetRemoteMacAddr()); } }를 구성하기 위해 먼저 IP 주소를 매개변수로 가져옵니다.
위 내용은 클라이언트 IP 주소 및 MAC 주소를 얻는 Java 공유 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

클래스 로더는 통합 클래스 파일 형식, 동적로드, 부모 위임 모델 및 플랫폼 독립적 인 바이트 코드를 통해 다른 플랫폼에서 Java 프로그램의 일관성과 호환성을 보장하고 플랫폼 독립성을 달성합니다.

Java 컴파일러가 생성 한 코드는 플랫폼 독립적이지만 궁극적으로 실행되는 코드는 플랫폼 별입니다. 1. Java 소스 코드는 플랫폼 독립적 인 바이트 코드로 컴파일됩니다. 2. JVM은 바이트 코드를 특정 플랫폼의 기계 코드로 변환하여 크로스 플랫폼 작동을 보장하지만 성능이 다를 수 있습니다.

멀티 스레딩은 프로그램 대응 성과 리소스 활용을 향상시키고 복잡한 동시 작업을 처리 할 수 있기 때문에 현대 프로그래밍에서 중요합니다. JVM은 스레드 매핑, 스케줄링 메커니즘 및 동기화 잠금 메커니즘을 통해 다양한 운영 체제에서 멀티 스레드의 일관성과 효율성을 보장합니다.

Java의 플랫폼 독립성은 작성된 코드가 수정없이 JVM이 설치된 모든 플랫폼에서 실행될 수 있음을 의미합니다. 1) Java 소스 코드는 바이트 코드로 컴파일됩니다. 2) 바이트 코드는 JVM에 의해 해석되고 실행됩니다.

javaapplicationscanindeedencounterplatform-specificissuesdespitetejvm'sabstraction.ressistinclude : 1) nativecodeandlibraries, 2) OperatingSystemDifferences, 3) jvmimplementationvariations, 및 4) 어려운 의존성, 개발자, 1)

클라우드 컴퓨팅은 Java의 플랫폼 독립성을 크게 향상시킵니다. 1) Java Code는 바이트 코드로 컴파일되어 다른 운영 체제에서 JVM에 의해 실행되어 크로스 플랫폼 작동을 보장합니다. 2) Docker 및 Kubernetes를 사용하여 Java 응용 프로그램을 배포하여 휴대 성 및 확장 성을 향상시킵니다.

Java'SplatformIndencealLowsDeveloperstowStowRiteCodeOntOnitOniNanyDeviceOroswithajvm. ThisIsachieAdthroughCompilingTobyTecode, thejvMIngretSorcompileStruntime.thistureatureDificallyNatlyBoostedjava'SADOPTIONDUOCROSS-PLAT-PLAT-PLAT-PLAT-PLAT-PLAT-PLAT-PLAT-PPLATION

Docker와 같은 컨테이너화 기술은 Java의 플랫폼 독립성을 대체하기보다는 향상됩니다. 1) 환경 간 일관성을 보장, 2) 특정 JVM 버전을 포함한 종속성 관리, 3) 배포 프로세스를 단순화하여 Java 응용 프로그램을보다 적응 가능하고 관리 할 수 있도록합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

Dreamweaver Mac版
시각적 웹 개발 도구

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는
