zoukankan      html  css  js  c++  java
  • URL传递中文字符,特殊危险字符的解决方案(仅供参考)urldecode、base64_encode

    很多时候,我们需要在url中传递中文字符或是其它的html等特殊字符,似乎总会有各种乱,不同的浏览器对他们的编码又不一样,

    对于中文,一般的做法是:

    把这些文本字符串传给url之前,先进行urlencode($text)一下;

    但是对于一些很“危险”的字符,比如说html字符,甚至是SQL注入相关的字符,如果很明显的传给系统,出于安全考虑,系统一般都会把它们过滤掉的。

    现在,我们需要这些危险字符,该这么办?

    我想到的办法是 先给它们 base64_encode($text) 编码,到服务端时,又给它们 base64_decode($text) 解码,

    貌似很完美,但是在使用的过程中又遇到一个问题,base64_encode 编码后的字符串中含有 "/", "+", "=" 等字符,

    这些字符在url编码中又是特殊字符,比如 "+" ,它就表示 “空格”,但是不同的浏览器对“空格”的编码又不一样,有的是用“+”表示,有的是用“20%”表示,也就是说,让这些base64_encode编码后的字符串在url中传递,用不同的浏览器去浏览时,服务端得到值不一样。

    于是乎,想到了一个折中办法,先将这些base64编码后的特殊字符替换掉,到服务端后,又替换回来:

    <?php
    function base_encode($str) {
    	$src = array("/", "+", "=");
    	$dist = array("_a", "_b", "_c");
    	$old = base64_encode($str);
    	$new = str_replace($src, $dist, $old);
    
    	return $new;
    }
    
    function base_decode($str) {
    	$src = array("_a", "_b", "_c");
    	$dist = array("/", "+", "=");
    	$old = str_replace($src, $dist, $str);
    	$new = base64_decode($old);
    
    	return $new;
    }

    下面是在浏览器中得到的效果

    xOO6w6Osuf65_aiy_atL_b00Ke5_b8jnus6ho6GjoaM_c

    呵呵,看看效果如何。。。

  • 相关阅读:
    php_package v2.7发布了 宋正河作品
    svn图文教程-宋正河整理
    ci框架学习整理
    php+mysql 数据库分表分段备份程序--宋正河
    保留mysql数据库中的最新1000条记录
    php 文件上传缩略图路径分析类
    php js css加载合并函数 宋正河整理
    二级域名 cookie session 共享
    图像处理相关概念
    由Python到深度学习入门之Keras、TensorFlow 、PyTorch联系与区别
  • 原文地址:https://www.cnblogs.com/52php/p/5687436.html
Copyright © 2011-2022 走看看