US-ASCII encryption is to convert 7bit to 8bit
Original code
Program code:
Program code
<Html>
<Title> sprites Blog </title>
<Script> alert (Hello World) </script>
<Body>
<A href = "http://www.spr1t3.comhttp: // www.spr1t3.com"> http://www.spr1t3.com </a>
</Body>
</Html>
Encrypted code
Program code:
Program code
<Html>
<Head>
<Meta http-equiv = "Content-Type" content = "text/html; charset = US-ASCII"/>
<Title> IE </title>
</Head> <body>
Zookeeper zookeeper why?
</Body> Encryption and decryption program
Program code:
Program code
# Include <stdio. h>
Int main (int argc, char ** argv)
{
FILE * fp;
Char ch;
Printf ("-- Bypassing of web filters by using ASCII Exploit By CoolDiyer --");
If (argc <2 ){
Printf ("Usage: % s srcfile> destfile", argv [0]);
Return-1;
}
If (fp = fopen (argv [1], "r") = NULL ){
Printf ("File % s open Error", argv [1]);
Return-1;
} // Specifies that encoding is required for the US-ASCII
Printf ("While (ch = fgetc (fp ))! = EOF ){
Ch | = 0x80; // convert 7-bit to 8-bit. This statement is the core and ch & = 0x7f is used for decryption.
Printf ("% c", ch );
};
Fclose (fp );
Printf ("</body> Return-1;
}
For decryption, you only need to set the height of each byte to 0. Another simpler method is to change "Western Europe (windows)" to "simplified GB2312" in the language option when saving the webpage as "Save as", and then save it locally.
Before unicode encoding
Program code:
Program code
<Html>
<Title> 7 jdgs Blog </title>
<Script> alert (Hello World) </script>
<Body>
<A href = "http://1v1.namehttp: // 1v1. name"> http://1v1.name </a>
</Body>
</Html>
Unicode encoded form
Program code:
Program code
<Html>
<Title> 7 jdgs Blog </title>
<Script> alert (Hello World) </script>
<Body>
<A href = "http://1v1.namehttp: // 1v1. name"> http://1v1.name </a>
</Body>
</Html>
Encryption program
Program code:
Program code
<?
$ Text = "http://1v1.name ";
Preg_match_all ("/[x80-xff]?. /", $ Text, $ ar );
Foreach ($ ar [0] as $ v)
Echo "& #". utf8_unicode (iconv ("GB2312", "UTF-8", $ v )).";";
?>
<?
// Utf8-> unicode
Function utf8_unicode ($ c ){
Switch (strlen ($ c )){
Case 1:
Return ord ($ c );
Case 2:
$ N = (ord ($ c [0]) & 0x3f) <6;
$ N + = ord ($ c [1]) & 0x3f;
Return $ n;
Case 3:
$ N = (ord ($ c [0]) & 0x1f) <12;
$ N + = (ord ($ c [1]) & 0x3f) <6;
$ N + = ord ($ c [2]) & 0x3f;
Return $ n;
Case 4:
$ N = (ord ($ c [0]) & 0x0f) <18;
$ N + = (ord ($ c [1]) & 0x3f) <12;
$ N + = (ord ($ c [2]) & 0x3f) <6;
$ N + = ord ($ c [3]) & 0x3f;
Return $ n;
}
}
?>
Such unicode encoding can also be saved as decryption.
Or
Program code:
Program code
<? Php
$ Str = "http://1v1.name ";
$ Str = preg_replace ("| & # ([0-9] {1, 5}); |", "". u2utf82gb (\ 1). "", $ str );
$ Str = "$ str =" $ str ";";
Eval ($ str );
Echo $ str;
Function u2utf82gb ($ c ){
$ Str = "";
If ($ c <0x80 ){
$ Str. = $ c;
} Else if ($ c <0x800 ){
$ Str. = chr (0xC0 | $ c> 6 );
$ Str. = chr (0x80 | $ c & 0x3F );
} Else if ($ c <0x10000 ){
$ Str. = chr (0xE0 | $ c> 12 );
$ Str. = chr (0x80 | $ c> 6 & 0x3F );
$ Str. = chr (0x80 | $ c & 0x3F );
} Else if ($ c <0x200000 ){
$ Str. = chr (0xF0 | $ c> 18 );
$ Str. = chr (0x80 | $ c> 12 & 0x3F );
$ Str. = chr (0x80 | $ c> 6 & 0x3F );
$ Str. = chr (0x80 | $ c & 0x3F );
}
Return iconv (UTF-8, GB2312, $ str );
}
?>