我正在尝试创建一个您可以访问的页面,该页面将显示系统信息。例如操作系统、主机名、用户名、域、系统品牌/型号等。最好的方法是什么?我认为它不能简单地通过 html 来完成,java 会是最好的选择吗?有什么建议么?主要是我只是希望用户不必下载应用程序或任何东西来获取信息并将其显示在网站上。不过,允许 java 运行之类的东西是可以接受的。
问问题
1563 次
5 回答
1
以下站点显示了您可以通过浏览器获得的有关客户端计算机的信息类型。请记住,您通过浏览器获得的任何信息都是“非权威的”(即可以被欺骗)。
这包括操作系统、位置以及有关浏览器和功能的许多详细信息。
您可以通过使用 Java Applet、要求安装浏览器插件或下载应用程序来获取更多信息。
于 2013-12-11T16:13:06.580 回答
0
如果可以接受 Java 小程序,您可能会在此处找到(部分)您的答案。
于 2013-12-11T15:55:43.137 回答
0
也许您可以使用一个名为 Sugar 的库,在此链接中您可以下载所需的文件以读取系统信息
于 2013-12-11T16:16:23.233 回答
0
如果您不介意使用 PHP:链接。它也可以在 JavaScript 中完成navigator.userAgent
。虽然,它只提供操作系统和浏览器。
请记住,userAgent 是可以伪造的。
于 2013-12-11T16:06:04.703 回答
0
为了获取使用 Html 和 JavaScript 的用户的系统详细信息,请使用以下代码。 该代码不执行任何类型的恶意活动
我已经为我的一个项目编写了此代码作为“系统详细信息”。
忽略样式并根据您的选择设置样式
<!DOCTYPE html>
<meta charset="utf-8">
<title>System Details</title>
<meta name="description" content="">
<meta name="author" content="">
<!-- mobile specific metas
================================================== -->
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
<!-- CSS
================================================== -->
<link rel="stylesheet" href="css/base.css">
<!-- script
================================================== -->
<script src="js/modernizr.js"></script>
<!-- favicons
================================================== -->
<link rel="icon" type="image/png" href="favicon.png">
<style>
body {
font-size: 14px;
font-family: georgia;
background-color: black;
color: white;
text-align: center;
line-height: 1.2;
}
span{
color:red;
}
</style>
</style>
<style>
p {
color: green;
}
</style>
<style>
h3 {
word-spacing: 200;
color: red;
}
</style>
<style>
h4 {
color: yellow;
}
</style>
<script src=
"https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js">
</script>
<script>
/* Add "https://api.ipify.org?format=json" statement
this will communicate with the ipify servers in
order to retrieve the IP address $.getJSON will
load JSON-encoded data from the server using a
GET HTTP request */
$.getJSON("https://api.ipify.org?format=json",
function(data) {
// Setting text of element P with id gfg
$("#gfg").html(data.ip);
})
</script>
<body id="body", onload="getLocation(),getHeaders()">
<hr/ style="color: red;">
<h3>_-_-_-Your System Details_-_-_-</h3>
<style>
h2{
color:green;
}
</style>
<hr/ style="color: red;">
<br>
<hr/style="color: green;">
PAGE DETAILS
<p id="demo-1"></p>
<script>
document.getElementById("demo-1").innerHTML ="<span>Page URL is : </span>" + window.location.href;
</script>
<p id="demo-2"></p>
<script>
document.getElementById("demo-2").innerHTML ="<span>Page hostname is : </span>" + window.location.hostname;
</script>
<p id="demo-3"></p>
<script>
document.getElementById("demo-3").innerHTML ="<span>Page pathname is : </span>" + window.location.pathname;
</script>
<p id="demo-4"></p>
<script>
document.getElementById("demo-4").innerHTML ="<span>Page protocol is : </span>" + window.location.protocol;
</script>
<p id="demo-5"></p>
<script>
document.write("<span>This site was last updated on </span>" + document.lastModified);
</script>
<hr/style="color: green;">
<br>
<hr/style="color: white;">
MOUSE LOCATION<BR>
<br>
<div id='info'></div>
<script type="text/javascript">
// Getting 'Info' div in js hands
var info = document.getElementById('info');
// Creating function that will tell the position of cursor
// PageX and PageY will getting position values and show them in P
function tellPos(p){
info.innerHTML = '<span>Your Cursor is at Position X : </span>' + p.pageX + ' <span>Position Y : </span>' + p.pageY;
}
addEventListener('mousemove', tellPos, false);
</script>
<style type="text/css">
* {
/*transition: 0.2s all ease;*/
}
</style>
<hr/style="color: white;">
<style>
note{
color:blue;
text-transform: capitalize;
}
</style>
<style>
note1{
color:cyan;
text-transform: capitalize;
}
</style>
<br>
<hr/style="color: blue;">
<nm style="color: white;">BROWSER DETAILS</nm>
<br><br>
<p id="demo1"></p>
<script>
document.getElementById("demo1").innerHTML =
"<span>App-Name is :</span>" + navigator.appName + "<span>, App-Code-Name is: </span>" + navigator.appCodeName + "<span>, Browser Engine is: </span> " + navigator.product;
</script>
<p id="demo33"></p>
<script>
document.getElementById("demo33").innerHTML =
"<span>your product sub is: </span> " + navigator.productSub;
</script>
<p id="demo333"></p>
<script>
document.getElementById("demo333").innerHTML =
"<span>your vendor is: </span> " + navigator.vendor+ "<and> & </and>"+ "<span>your vendor sub is: </span> " + navigator.vendorSub;
</script>
<p id="demo4"></p>
<script>
document.getElementById("demo4").innerHTML ="<span>Browser version is: </span> " + navigator.appVersion + "<span>, Browser platform is: </span> " + navigator.platform;
</script>
<p id="demo666"></p>
<script>
document.getElementById("demo666").innerHTML = "<span>Hardware concurrency is: </span> " + navigator.hardwareConcurrency + "<span>, Build ID is: </span> " + navigator.buildID;
</script>
<p id="demo5"></p>
<script>
document.getElementById("demo5").innerHTML = "<span>your Browser is: </span> " + navigator.userAgent;
</script>
<p id="demo7"></p>
<script>
document.getElementById("demo7").innerHTML ="<span>your Browser languages are: </span> " + navigator.languages;
</script>
<p id="demo0"></p>
<style>
p{
color:purple;
text-transform: uppercase;
}
</style>
<style>
span{
color:orange;
text-transform: capitalize;
}
</style>
<style>
and{
color:blue;
}
</style>
<script>
document.getElementById("demo0").innerHTML =
"<span>Cookie enabled is: </span>" + navigator.cookieEnabled+"<and> &</and>"+"<span> Java Enabled is: </span>" +navigator.javaEnabled();;
</script>
<p id="demo011"></p>
<script>
document.getElementById("demo011").innerHTML =
"<span>Do not track (1 (ON) & 0 (OFF)): </span>" + navigator.doNotTrack;
</script>
<hr/style="color: blue;">
<br>
<hr/style="color: orange;">
SCREEN & DEVICE DETAILS
<p id="demo10"></p>
<script>
document.getElementById("demo10").innerHTML ="<span>Screen Width: </span>" + screen.width;
</script>
<p id="demo11"></p>
<script>
document.getElementById("demo11").innerHTML ="<span>Screen Height: </span>" + screen.height;
</script>
<b><p id="demo9"></p></b>
<script>
document.getElementById("demo9").innerHTML ="<span>Screen Resolution: </span>" + screen.width +"<span> x </span>"+screen.height;
</script>
<p id="demo12"></p>
<script>
document.getElementById("demo12").innerHTML =" <span>Available Screen Width: </span>" + screen.availWidth;
</script>
<p id="demo13"></p>
<script>
document.getElementById("demo13").innerHTML ="<span> Available Screen Height: </span>" + screen.availHeight;
</script>
<p id="demo131"></p>
<script>
document.getElementById("demo131").innerHTML ="<span> Orientation: </span>" + screen.orientation.type;
</script>
<p id="demo14"></p>
<script>
document.getElementById("demo14").innerHTML ="<span>Screen Color Depth: </span>" + screen.colorDepth+"<and> & </and>"+"<span>Screen Pixel Depth: </span>" + screen.pixelDepth;
</script>
<p id="-6"></p>
<script type="text/javascript">
var isMobile = /iPhone|iPad|iPod|Android|Tablet/i.test(navigator.userAgent);
var element = document.getElementById('-6');
if (isMobile) {
element.innerHTML = "<span>You are using: </span> Mobile";
} else {
element.innerHTML = "<span>You are using: </span> Desktop";
}
</script>
<p id="demo66"></p>
<script>
document.getElementById("demo66").innerHTML = "<span>your oscpu (Operating System | CPU) is: </span> " + navigator.oscpu;
</script>
<p id="demo78"></p>
<script>
document.getElementById("demo78").innerHTML = "<span>your device memory is: </span> " + navigator.deviceMemory;
</script>
<hr/style="color: orange;">
<BR>
<hr/style="color: purple;">
BATTERY STATUS
<article class="battery-card">
<h1 class="battery-title"></h1>
<div class="battery-box">
<strong class="battery-percentage"></strong>
<i class="battery"></i>
</div>
<dl class="battery-info">
<dt><span>Power Source</span></dt>
<dd class="battery-status"><p>---</p></dd>
<dt><span>Level percentage</span></dt>
<dd class="battery-level"><p>---</p></dd>
<dt><span>Fully charged in</span></dt>
<dd class="battery-fully"><p>---</p></dd>
<dt><span>Remaining time</span></dt>
<dd class="battery-remaining"><p>---</p></dd>
</dl>
</article>
<script type="text/javascript">
(function() {
'use strict';
var battery;
function toTime(sec) {
sec = parseInt(sec, 10);
var hours = Math.floor(sec / 3600),
minutes = Math.floor((sec - (hours * 3600)) / 60),
seconds = sec - (hours * 3600) - (minutes * 60);
if (hours < 10) { hours = '0' + hours; }
if (minutes < 10) { minutes = '0' + minutes; }
if (seconds < 10) { seconds = '0' + seconds; }
return hours + ':' + minutes;
}
function readBattery(b) {
battery = b || battery;
var percentage = parseFloat((battery.level * 100).toFixed(2)) + '%',
fully,
remaining;
if (battery.charging && battery.chargingTime === Infinity) {
fully = '<p>Calculating...</p>';
} else if (battery.chargingTime !== Infinity) {
fully = toTime(battery.chargingTime);
} else {
fully = '---';
}
if (!battery.charging && battery.dischargingTime === Infinity) {
remaining = '<p>Calculating...</p>';
} else if (battery.dischargingTime !== Infinity) {
remaining = toTime(battery.dischargingTime);
} else {
remaining = '<p>---<?p>';
}
document.styleSheets[0].insertRule('.battery:before{width:' + percentage + '}', 0);
document.querySelector('.battery-percentage').innerHTML = percentage;
document.querySelector('.battery-status').innerHTML = battery.charging ? '<p>Adapter (charging)</p>' : '<p>Battery (not charging)</p>';
document.querySelector('.battery-level').innerHTML = percentage;
document.querySelector('.battery-fully').innerHTML = fully;
document.querySelector('.battery-remaining').innerHTML = remaining;
}
if (navigator.battery) {
readBattery(navigator.battery);
} else if (navigator.getBattery) {
navigator.getBattery().then(readBattery);
} else {
document.querySelector('.not-support').removeAttribute('hidden');
}
window.onload = function () {
battery.addEventListener('chargingchange', function() {
readBattery();
});
battery.addEventListener("levelchange", function() {
readBattery();
});
};
}());
</script>
<hr/style="color: purple;">
<br>
<hr/style="color: cyan;">
DATE & TIME
<p>
<script language="JavaScript" type="text/javascript">
now= new Date();
localtime=now.toString();
utctime =now.toUTCString();
document.write("<span>your local time is:</span>" + localtime +"<BR>");
document.write("<br><span>UTC time (Actual) is:</span>" + utctime);
</script>
</p>
<hr/style="color: cyan;">
<br>
<hr/style="color: green;">
IP ADDRESS
<p><span>Your Public IP Address is:</span>
<p id="gfg"></p>
<span>Your Private / Local Machine IP</span><br><br>
<div id="-9"></div>
<style>
div{
color: purple;
}
</style>
<style>
iv{
color: purple;
}
</style>
<script >
var RTCPeerConnection = /*window.RTCPeerConnection ||*/ window.webkitRTCPeerConnection || window.mozRTCPeerConnection;
if (RTCPeerConnection)(function() {
var rtc = new RTCPeerConnection({
iceServers: []
});
if (1 || window.mozRTCPeerConnection) {
rtc.createDataChannel('', {
reliable: false
});
};
rtc.onicecandidate = function(evt) {
if (evt.candidate) grepSDP("a=" + evt.candidate.candidate);
};
rtc.createOffer(function(offerDesc) {
grepSDP(offerDesc.sdp);
rtc.setLocalDescription(offerDesc);
}, function(e) {
console.warn("offer failed", e);
});
var addrs = Object.create(null);
addrs["0.0.0.0"] = false;
function updateDisplay(newAddr) {
if (newAddr in addrs) return;
else addrs[newAddr] = true;
var displayAddrs = Object.keys(addrs).filter(function(k) {
return addrs[k];
});
document.getElementById('-9').textContent = displayAddrs.join(" |or perhaps| ") || "n/a";
}
function grepSDP(sdp) {
var hosts = [];
sdp.split('\r\n').forEach(function(line) {
if (~line.indexOf("a=candidate")) {
var parts = line.split(' '),
addr = parts[4],
type = parts[7];
if (type === 'host') updateDisplay(addr);
} else if (~line.indexOf("c=")) {
var parts = line.split(' '),
addr = parts[2];
updateDisplay(addr);
}
});
}
})();
else {
document.getElementById('list').innerHTML = "<code>ifconfig| grep inet | grep -v inet6 | cut -d\" \" -f2 | tail -n1</code>";
document.getElementById('list').nextSibling.textContent = "In Chrome and Firefox your IP should display automatically, by the power of WebRTCskull.";
}
</script>
<hr/style="color: green;">
<br>
<hr/style="color: blue;">
YOUR LOCATION<br>
<style>
clk{
color: green;
}
</style>
<note1>Note:</note1> <clk>(Click here)</clk><note> to check your Location (Browser Based).</note>
<body onclick="getLocation()">
<p id="22"></p>
<script>
var x = document.getElementById("22");
function getLocation() {
if (navigator.geolocation) {
navigator.geolocation.getCurrentPosition(showPosition);
} else {
x.innerHTML = "<span>Geolocation is not supported by this browser.</span>";
}
}
function showPosition(position) {
x.innerHTML = "<span>Latitude: </span>" + position.coords.latitude +"<and> & </and>"+ "<span>Longitude: </span>" + position.coords.longitude;
}
</script>
<hr/style="color: blue;">
<br>
<hr/>
NETWORK DETAILS<br><br>
<div id="network"></div>
<script>
$.get("https://ipinfo.io/json", function (response) {
$("#ip").html("<span>IP: </span>" + response.ip);
$("#address").html("<span>Location: </span>" + response.city + ", " + response.region);
$("#details").html(JSON.stringify(response, null, 4));
}, "jsonp");
</script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<style>
hr, pre{
line-height: 1.2;
color: red;
}
</style>
<div id="ip"></div>
<div id="address"></div><br>
<span>Full response: </span><pre id="details"></pre>
<hr/>
FURTHER MORE NETWORK DETAILS
<div id="000"></div>
<script>
$.get("https://api.ipdata.co?api-key=test", function (response) {
$("#response").html(JSON.stringify(response, null, 4));
$("#country").html('Country: ' + response.country_name);
$("#region").html('Region ' + response.region);
$("#city").html('City' + response.city);
}, "jsonp");
</script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="country"></div>
<div id="region"></div>
<div id="city"></div>
<pre id="response"></pre>
<hr/style="color: red;">
<br>
<hr/style="color: yellow;">
HTTP HEADERS<BR>
<style type="text/css">
c{
line-height: 1;
color: purple;
}
</style>
<c id="demoz"></c>
<script type="text/javascript">
function getHeaders() {
var req = new XMLHttpRequest();
req.open('GET', document.location, false);
req.send(null);
// associate array to store all values
var data = new Object();
// get all headers in one call and parse each item
var headers = req.getAllResponseHeaders().toLowerCase();
var aHeaders = headers.split('\n');
var i =0;
for (i= 0; i < aHeaders.length; i++) {
var thisItem = aHeaders[i];
var key = thisItem.substring(0, thisItem.indexOf(':'));
var value = thisItem.substring(thisItem.indexOf(':')+1);
data[key] = value;
}
// get referer
var referer = document.referrer;
data["Referer"] = referer;
//get useragent
//var useragent = navigator.userAgent;
//data["UserAgent"] = useragent;
//extra code to display the values in html
var display = "";
for(var key in data) {
if (key != "")
display += "<span>" + key + "</span> : " + data[key] + "<br>";
}
document.getElementById("demoz").innerHTML = display;
}
</script>
<br>
<hr/style="color: yellow;">
<br>
<hr/style="color: blue;">
VPN OR BAD KNOWN IP
<div id="results">
<p id="detection-result"></p>
<div>
<h4 class="result"></h4>
<span id="browser-timezone" class="result"></span>
<h4 class="result"></h4>
<span id="ip-timezone" class="result"></span>
<span id="error-detail" class="error"></span>
</div>
</div>
<script type="text/javascript">
function detectVPN() {
var browserTimezone = Intl.DateTimeFormat().resolvedOptions().timeZone
return fetch(`https://ipapi.co/json`)
.then(function(response) { return response.json() })
.then(function (data) {
var ipTimezone = data.timezone
console.log(`browser timezone: ${browserTimezone}`, `ip timezone: ${ipTimezone}`)
return {
browser: browserTimezone,
ip: ipTimezone,
usingVPN: ipTimezone != browserTimezone
}
})
}
detectVPN()
.then(function(detectionResult) {
var body = document.getElementById('body')
var result = document.getElementById('detection-result')
var details = document.getElementsByClassName('result')
detectionResult.usingVPN ? result.textContent = "You are using a VPN or Known Bad IP" : result.textContent = "You are not using a VPN or Known Bad IP"
detectionResult.usingVPN ? body.style.backgroundColor = 'black' : body.style.backgroundColor = 'black'
body.style.color = 'white'
document.getElementById("browser-timezone").textContent = detectionResult.browser
document.getElementById("ip-timezone").textContent = detectionResult.ip
Array.prototype.forEach.call(details, d => d.style.display = 'block')
})
.catch(function(err) {
var body = document.getElementById('body')
var result = document.getElementById('detection-result')
var details = document.getElementsByClassName("error")
var errorDetail = document.getElementById('error-detail')
result.textContent = "There was an error detecting your VPN"
errorDetail.textContent = err.message
Array.prototype.forEach.call(details, d => d.style.display = 'block')
})
</script>
<br>
<hr/style="color: blue;">
TOR<br><br>
<div id="tor-browser-test"></div>
<script type="text/javascript">
function isTorBrowser() {
var img = document.createElement("img");
// Creates a black 1x1 px image
img.src = '';
var canvas = document.createElement("canvas");
canvas.width = 1;
canvas.height = 1;
var ctx = canvas.getContext("2d");
var imagedata = ctx.getImageData(0, 0, canvas.width, canvas.height);
return imagedata.data[0] == 255
&& imagedata.data[1] == 255
&& imagedata.data[2] == 255
&& imagedata.data[3] == 255;
}
document.getElementById('tor-browser-test').innerHTML = isTorBrowser() ? 'Is Tor' : 'Not Tor';
</script>
<hr/style="color: blue;">
<br>
<hr/style="color: orange;">
LOADING TIME<br><br>
<script type="text/javascript">
var before_loadtime = new Date().getTime();
window.onload = Pageloadtime;
function Pageloadtime() {
var aftr_loadtime = new Date().getTime();
// Time calculating in seconds
pgloadtime = (aftr_loadtime - before_loadtime) / 1000
document.getElementById("loadtime").innerHTML = "The results are fetched in <font color='purple'><b>" + pgloadtime + "</b></font> Seconds ";
}
</script>
<div>
<span id="loadtime"></span>
<br>
<hr/style="color: orange;">
<div class="credits" style="font-family: comic;">
<p style="color: silver; text-transform: lowercase;"><cpy1 style="color: white; text-transform: capitalize;">Copyright © 2020 | </cpy1> <cpy><cpy2 style=" text-transform: lowercase; color: white;">cqr</cpy2><cpy3 style="color: darkorange; text-transform: capitalize; ">Cyber</cpy3>.xyz </cpy></p>
</div>
</div>
</div> <!-- /row -->
</footer>
</div> <!-- /content-wrap -->
</main> <!-- /main-404-content -->
<div id="preloader">
<div id="loader"></div>
</div>
<!-- Java Script
================================================== -->
<script src="js/jquery-2.1.3.min.js"></script>
<script src="js/plugins.js"></script>
<script src="js/main.js"></script>
</body>
</html>
于 2020-09-25T05:31:01.730 回答