其實咱們都知道,開發很簡單,數據對接也不難,難的是標准的兼容。比如咱們是C#寫的代碼,對方是Java寫的或者是PHP寫的代碼,這個時候通用的倒是無所謂,但是部分寫法是某種語言專用的,因此可能兼容起來就非常的困難。比如對方給了個標准RSA加密,pkcs8,那么我們就得去深入研究了,今天我們討論的不是RSA的問題,而是BASE64加密的問題。
總所周知的,BASE64是通用算法,不同語言都應該有基礎框架支持這種編碼方式,而Java寫法里面,apche搞了個包org.apache.commons.codec.binary,這個包里面的Base64.encodeBase64URLSafe方法就比較奇葩,通過命名可以知道是安全的URL,通過名稱我們猜想應該是把Base64里面的等號(=)做了處理。這里就不細說了,咱們把C#里面的寫法共享出來,分享給大家。
C#咱們新增一個ConvertHelper類處理:
public class ConvertHelper { /// <summary> /// 將Java安全的base64字符串轉換為byte數組 /// </summary> /// <param name="convert"></param> /// <param name="javaURLSafeString"></param> /// <returns></returns> public static byte[] FromBase64StringURLSafe(string javaURLSafeString) { javaURLSafeString = javaURLSafeString.Replace("-", "+").Replace("_", "/"); var base64 = Encoding.ASCII.GetBytes(javaURLSafeString); var padding = base64.Length * 3 % 4;//(base64.Length*6 % 8)/2 if (padding != 0) { javaURLSafeString = javaURLSafeString.PadRight(javaURLSafeString.Length + padding, '='); } return Convert.FromBase64String(javaURLSafeString); } /// <summary> /// 將byte數組轉換為java安全的base64字符串 /// </summary> /// <param name="convert"></param> /// <param name="bytes"></param> /// <returns></returns> public static string ToBase64StringURLSafe(byte[] bytes) { string base64String = Convert.ToBase64String(bytes); return base64String.Replace("+", "-") .Replace("/", "_") .Replace("=", ""); } }
通過代碼我們可以明顯看出,實際上就是對+、/、=進行了特殊處理。