unblocker
Version:
Web proxy for evading internet censorship & general-purpose library for rewriting remote websites.
144 lines (113 loc) • 6.8 kB
HTML
<html>
<head>
<title>Node Unblocker</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
<!-- header font -->
<link href="//fonts.googleapis.com/css?family=Orbitron" rel="stylesheet" type="text/css">
<!-- body font -->
<link href="//fonts.googleapis.com/css?family=Droid+Sans" rel="stylesheet" type="text/css">
<style type="text/css">
/* fonts */
body { font-family: 'Droid Sans', arial, serif; letter-spacing: 1px;}
h1 { font-family: 'Orbitron', arial, serif; letter-spacing: 2px;}
h2, h3, h4, h5, h6 { letter-spacing: 2px; font-weight: normal;}
/* colors */
body { background-color: #000306; color: white;}
.container { background-color: #3F4038; border-color: #5B3E38}
a { color: #62BECB; }
a:hover {color: #82DEEB }
#error { border:1px dotted white; background: brown; }
/* stripes and borders */
.main { background-repeat: repeat-x; background-image: url(); }
.footer { min-height: 60px; background-repeat: repeat-x; background-position: bottom left; background-image: url(); }
.container { border-style: solid; border-width: 1px; border-radius: 10px; -moz-border-radius: 10px; -webkit-border-radius: 10px; overflow:hidden; /* otherwise the background image appears on top of the curved border */ }
/* layout */
body { text-align: center; }
.container { width: 760px; margin: 40px auto; text-align: left; max-width: calc(100% - 10px);}
h2, h3, h4, h5, h6 { margin-bottom: 0; }
ul { line-height: 150%; }
ul, p { margin-top: 5px; margin-bottom: 0; }
.main, .footer { padding: 1px 10px 0 10px; }
#error {display: none; padding: 5px 10px; margin: 30px 10px; }
form ul { list-style-type: none; padding-left: 25px;}
input[type=text] { width: 640px; max-width: calc(100% - 8em) }
.footer { position: relative; clear: both;}
.footer p { margin:0; position: absolute; bottom: 10px; right: 10px; padding-left: 10px; }
#google-ad {
text-align: center;
margin: 10px auto;
}
@media(min-width: 768px) {
#google-ad {
margin: 0;
float:right;
margin:4px 2px 2px 20px;
}
}
</style>
</head>
<body>
<div class="container">
<div class="main">
<h1>Node Unblocker</h1>
<div id="error"></div>
<form action="no-js" method="get" id="unblocker-form">
<p>
URL:
<input type="text" id="url" name="url" autofocus="autofocus" />
<input type="submit" value="Go" />
</p>
</form>
<div id="google-ad">
<script async src="//pagead2.googlesyndication.com/pagead/js/adsbygoogle.js"></script>
<!-- Nodeunblocker.com -->
<ins class="adsbygoogle"
style="display:inline-block;width:336px;height:280px"
data-ad-client="ca-pub-9477050254721722"
data-ad-slot="3464697570"></ins>
<script>
(adsbygoogle = window.adsbygoogle || []).push({});
</script>
</div>
<h3>About Node Unblocker</h3>
<p>Node Unblocker is a web proxy, similar to CGIProxy, PHProxy, or Glype, that allows users to evade filters and censorship and access blocked websites. </p>
<p>It's designed to be extremely fast and compatible: It processes the data on-the-fly rather than buffering the entire response, and it only modifies URLs when necessary - relative ones will "just work". </p>
<p>Node Unblocker is written in JavaScript with <a href="http://nodejs.org">node.js</a>. The source code is <a href="https://github.com/nfriedly/node-unblocker">available on github</a>.</p>
</div>
<div class="footer">
<p><a href="https://github.com/nfriedly/node-unblocker">Node Unblocker</a> by <a href="http://www.nfriedly.com/" title="Node.js developer and JavaScript Expert">Nathan Friedly</a></p>
</div>
</div>
<script>
function $(id){
return document.getElementById(id);
}
$('unblocker-form').onsubmit = function(){
var url = $('url').value;
if(url.substr(0,4) != "http"){
url = "http://" + url;
}
window.location.pathname = 'proxy/' + url;
return false;
};
function checkError(){
var search = window.location.search;
var start = search.indexOf('error=');
if(start > -1){
var stop = search.indexOf('&', start);
if(stop == -1){ stop = undefined; }
// +6 for "error="
var err = search.substr(start+6, stop);
var $error = $('error');
$error.innerText = $error.textContent = decodeURIComponent(err);
$error.style.display = "block";
}
}
window.onload = function() {
$('url').focus();
checkError();
}
</script>
</body>
</html>