Chinaunix

标题: [已解决]shell的base64为什么和java里apache的commons-codec的base64得到的结果不同? [打印本页]

作者: 19774279    时间: 2014-12-31 10:18
标题: [已解决]shell的base64为什么和java里apache的commons-codec的base64得到的结果不同?
本帖最后由 19774279 于 2015-06-23 09:50 编辑

shell的命令是:echo 111111 | base64,得到MTExMTExCg==
Java是byte[] decodedBytes = Base64.decodeBase64("111111");           return new String(decodedBytes);得到MTExMTEx

我想要的需求其实是这样:分别用shell命令和java代码对同一个字符串进行处理,使其转换为另外一个字符串(类似于加密,但是不需要解密,得到的结果越长越好)。
因为我的shell很烂,对加解密更是一窍不通,所以没有自己写,就想用现成的base64,居然结果不同,不知道还有什么能满足我需求的命令吗?
注意:由于某些原因,shell的机器和执行java代码的机器不能互相访问,无法共享相同的随机数,所以需要自己生成。
作者: Buring__    时间: 2014-12-31 10:28
回复 1# 19774279
  1. echo -n 111111|base64
  2. MTExMTEx
复制代码
这样就一样了 :)
作者: Looiml    时间: 2014-12-31 10:38
回复 2# Buring__
切中要害,一语中的。
作者: Buring__    时间: 2014-12-31 15:37
Looiml 是最近新来的大神啊{:3_193:}
作者: Looiml    时间: 2014-12-31 15:57
回复 4# Buring__
过誉了,大神实在是不敢当,草民惶恐!
书上学来终觉浅,才来论坛学习的,根据以往的经验,拿得出手的炫技都是在论坛泡出来的,各位都可能是在下的老师。
   
作者: Buring__    时间: 2014-12-31 16:14
回复 5# Looiml


    书上学来终觉浅,来到论坛勤躬行
作者: liion631818    时间: 2014-12-31 16:59
  1. base64Table=(A B C D E F G H I J K L M N O P Q R S T U V W X Y Z a b c d e f g h i j k l m n o p q r s t u v w x y z 0 1 2 3 4 5 6 7 8 9 + /);

  2. function str2binary() {
  3.         idx=0;
  4.         for((i=0; i<${#str}; i++)); do
  5.                 dividend=$(printf "%d" "'${str:i:1}");
  6.                 for((j=0;j<8;j++)); do
  7.                         let idx=8*i+7-j;
  8.                         let bin[$idx]=$dividend%2;
  9.                         dividend=$dividend/2;
  10.                 done;
  11.         done;
  12.         let idx=${#str}*8;
  13.         for((i=0; i<appendEqualCnt*2; i++)); do
  14.                 let bin[$idx]=0;
  15.                 let idx++;
  16.         done;
  17. }
  18. function calcBase64() {
  19.         for((i=0; i<${#bin[*]}/6; i++)); do
  20.                 sum=0;
  21.                 for((j=0; j<6; j++)); do
  22.                         let idx=i*6+j;
  23.                         let n=6-1-j;
  24.                         let sum=sum+${bin[$idx]}*2**n;
  25.                 done;
  26.                 echo -n ${base64Table[$sum]};
  27.         done
  28. }

  29. declare -a bin
  30. function base64Encode() {
  31.         read -p "please enter ASCII string:" str;
  32.         let appendZero=${#str}*8%6;
  33.         let bits=${#str}*8;
  34.         appendEqualCnt=0;
  35.         if [[ $appendZero -ne 0 ]]; then
  36.                 let appendEqualCnt=(6-$appendZero)/2;
  37.         fi
  38.         str2binary;
  39.         calcBase64;
  40.         if [[ $appendEqualCnt -eq 2 ]]; then
  41.                 echo -n "==";
  42.         elif [[ $appendEqualCnt -eq 1 ]]; then
  43.                 echo -n "=";
  44.         fi
  45.         echo;
  46.        
  47. }
复制代码

作者: 19774279    时间: 2015-06-23 09:49
2楼的方法很好,可以解决问题




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2