php仿javascript的escape和unescape用于简单网页加密

 突发奇想,我的文章内容在正常访问的时候是可以看到正常效果的,而我让用户查看源代码的时候就是一团乱码。

于是我想到了javascript的escape,但是这样一样,必须要在网页输出的时候就要被加密了的。在客户端 再用javascript的unescape的函数解回。

大概做了个页面如下

function.php

  1. function   escape($str){ 
  2.         preg_match_all( "/[/x80-/xff].|[/x01-/x7f]+/ ",$str,$newstr); 
  3.         $ar   =   $newstr[0]; 
  4.         foreach($ar   as   $k=> $v){ 
  5.                 if(ord($ar[$k])> =127){ 
  6.                         $tmpString=bin2hex(iconv( "GBK ""ucs-2 ",$v)); 
  7.                         if   (!eregi( "WIN ",PHP_OS)){ 
  8.                                 $tmpString   =   substr($tmpString,2,2).substr($tmpString,0,2); 
  9.                         } 
  10.                         $reString.= "%u ".$tmpString; 
  11.                 }   else   { 
  12.                         $reString.=   rawurlencode($v); 
  13.                 } 
  14.         } 
  15.         return   $reString; 
  16. function   unescape($str)   { 
  17.     $str   =   rawurldecode($str); 
  18.     preg_match_all( "/(?:%u.{4})|&#x.{4};|&#/d+;|.+/U ",$str,$r); 
  19.     $ar   =   $r[0]; 
  20.     foreach($ar   as   $k=> $v)   { 
  21.         if(substr($v,0,2)   ==   "%u "){ 
  22. if   (!eregi( "WIN ",PHP_OS)){ 
  23. $tmpString   =   "%u ".substr($v,4,2).substr($v,2,2); 
  24.             $ar[$k]   =   iconv( "UCS-2 ""GB2312 ",pack( "H4 ",substr($tmpString,-4))); 
  25.   } 
  26.         elseif(substr($v,0,3)   ==   "&#x "
  27.             $ar[$k]   =   iconv( "UCS-2 ""GB2312 ",pack( "H4 ",substr($v,3,-1))); 
  28.         elseif(substr($v,0,2)   ==   "&# ")   { 
  29.             $ar[$k]   =   iconv( "UCS-2 ""GB2312 ",pack( "n ",substr($v,2,-1))); 
  30.         } 
  31.     } 
  32.     return   join( " ",$ar); 

test.php

 

  1. document.write(unescape('<?php echo escape('我是一个中国人,我为我是中国人而自豪。你想看我的源代码吗?那就看吧。');?>'));

当然了,这个加密是可以轻松被破解的。只是让普通用户无法获取我的源代码。

在我省略了页面控制部分。希望大家理解。

 

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值