PHP实现JavaScript的escape和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); 

 

document.write(unescape('<?php echo escape('测试,看看吧!');?>'));

 

ELSE


  function   escape($str)   {  
      preg_match_all("/[/x80-/xff].|[/x01-/x7f]+/",$str,$r);  
      $ar   =   $r[0];  
      foreach($ar   as   $k=>$v)   {  
  if(ord($v[0])   <   128)  
      $ar[$k]   =   rawurlencode($v);  
  else  
      $ar[$k]   =   "%u".bin2hex(iconv("BIG5","UCS-2",$v));  
      }  
      return   join("",$ar);  
  }   
   
  alert(unescape('$str'));

 

Else: http://topic.csdn.net/u/20080928/10/cde07c2d-5b07-4d98-8dfa-eb6ee7e28bad.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值