您好,登錄后才能下訂單哦!
怎么在Android中數據傳輸的參數進行加密?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
1、數據傳輸
1)、http請求中,最常用的方法有兩種:get和post;一般post請求適合做提交,而get請求適合做請求數據
2)、數據的加密,大概有三種常用的:AES,DES,Base64
2、Base64加密
這里使用的aes加密,然后再將字符串使用Base64編碼,其中有增加向量,是為了提高加密破解難度,一段參數加密的方法如下:
/** * 對post請求數據進行加密 * @param params * @return * @throws Throwable */ public static byte[] encryptParams(HashMap<String, String> params) throws Throwable{ if (params == null){ return null; } StringBuilder stringBuilder = new StringBuilder(); Iterator<Map.Entry<String, String>> iterator = params.entrySet().iterator(); while (iterator.hasNext()){ Map.Entry<String,String> entry = iterator.next(); String key = entry.getKey(); String value = entry.getValue(); if (stringBuilder.length() > 0){ stringBuilder.append("&"); } stringBuilder.append(key).append("=").append(Uri.encode(value)); } byte[] buff = stringBuilder.toString().getBytes("utf-8"); byte[] iv = new byte[16]; Random random = new Random(); random.nextBytes(iv); byte[] data = Aes.encrypt(buff,PASSWORD,iv); ByteArrayOutputStream baos = new ByteArrayOutputStream(); baos.write(iv,0,iv.length); baos.write(data,0,data.length); byte[] out = baos.toByteArray(); try { baos.close(); } catch (Throwable e){ e.printStackTrace(); } return out; }
3、遇到問題
在使用Base64的過程中,遇到一些問題,如下:
1)請求的字符串被截斷,抓取鏈接之后,得到一段空格的字符串。經過分析,其實這里是換行。。。。。
解決的方法是,在請求的時候,將輸出的字符串,做如下處理:
將 android.util.Base64.encodeToString(input, Base64.DEFAULT) 換成 android.util.Base64.encodeToString(input, Base64.NO_WRAP);
2)除了上面的是因為換行之外,其實也真的存在空格的情況,這個時候,可以使用替換,如下:
// 加密: byte[] bodyBytes = RequestManager.encryptParams(hashMap); // 使用base64encode做最后的加密 String result = new BASE64Encoder().encode(bodyBytes); String ans_url = headUrl + result.replaceAll("\n","");
4、總結
base64encode編碼會在76位之后,將字符串截斷。在含有中文字符串的情況下,會出現加號被替換成空格的情況。
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。