我不确定这是否是最快的方式,但无论如何它已经足够了=)希望你喜欢它
EDIT2在 JS 上完成!
var complexity = 0.3; // 0 to .99 if more then more letters in src string will be replaced by random ones
var randsArr = ("!@#$)**($#*)($#$()$()#$%^&*()%^$#$$#$^").split('').sort(function () { return 0.5 - Math.random()});
var srcArr = ("The brown fox jumps over the pink fence.").split('');
result = $.map(srcArr,function (el) { return (Math.random()>complexity) ? el : (randsArr.length) ? randsArr.shift() : el ; }).join('');
在 JSFiddle 上测试它
旧的 php 版本,以防万一有人需要它:
$rands = "!@#$%^&*()";
$srcStr = "The brown fox jumps over the pink fence.";
$srcArr = str_split ($srcStr);
$randsArr = array_merge(str_split($rands),array_fill(strlen($rands),strlen($srcStr)-strlen($rands),false));
shuffle($randsArr);
echo implode(array_map(function($letter,$replacement) { return ($replacement!=false)?$replacement:$letter; },$srcArr,$randsArr));
编辑我的错...我在想它是关于 php =( 给我几分钟在 JS 上重写它