システム情報を表示するページを作成しようとしています。OS、ホスト名、ユーザー名、ドメイン、システムのメーカー/モデルなど。これについて最善の方法は何ですか? 単純にhtmlで行うことはできないと思います.Javaが最良の選択肢でしょうか? 助言がありますか?主に、情報を取得してサイトに表示するために、ユーザーがアプリなどをダウンロードする必要がないようにしたいだけです。ただし、Javaの実行を許可するようなものは受け入れられます。
5 に答える
次のサイトでは、クライアント マシンについてブラウザから簡単に取得できる情報の種類を示しています。ブラウザを介して取得する情報は「非公式」であることに注意してください (つまり、なりすましの可能性があります)。
これには、オペレーティング システム、場所、およびブラウザと機能に関する多くの詳細が含まれます。
Java アプレットを使用したり、ブラウザ プラグインのインストールを要求したり、アプリケーションをダウンロードしたりすることで、より多くの情報を取得できます。
Sugar と呼ばれる 1 つのライブラリを使用することもできます。このリンクでは、必要なファイルをダウンロードしてシステム情報を読み取ることができます。
PHP を使用してもかまわない場合: link。JavaScript で行うこともできますnavigator.userAgent
。ただし、OSとブラウザのみを提供します。
userAgent は偽造できることに注意してください。
Html と JavaScript を使用してユーザーのシステムの詳細を取得するには、次のコードを使用します。 このコードは、いかなる種類の悪意のある活動も実行しません
このコードは、プロジェクトの 1 つに「システムの詳細」として記述しました。
スタイリングを無視して、選択したスタイルにします
<!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>