网站如何被百度快速收录,湖北阳新县建设局网站,沈阳定制网带式电加热烘箱,建站工具 ip如果你对于网络请求用了https后是否还有必要对参数加密有疑问可以看我上篇的文章#xff1a;网络安全https 记得耐心看完#xff0c;下面说问题#xff1a;
Caused by: java.lang.IllegalArgumentException: Unexpected char 0x0a 一开始以为是okhttp框架对特殊字符做了现在…如果你对于网络请求用了https后是否还有必要对参数加密有疑问可以看我上篇的文章网络安全https 记得耐心看完下面说问题
Caused by: java.lang.IllegalArgumentException: Unexpected char 0x0a 一开始以为是okhttp框架对特殊字符做了现在网上其他文章说的是对中文字符我想我这也没中文啊但还是全部换成原生试了一下果然还是一样报错坑爹的网友啊哈哈 下面是测试用例demo的代码
package com.tcssj.mbjmb;import android.util.Base64;
import android.view.View;import java.nio.charset.StandardCharsets;import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;public class AESUtil2 {public static byte[] base64ToDecode(String str) {byte[] byteStr Base64.decode(str, Base64.DEFAULT);return byteStr;}public static String encode(byte[] key) {return Base64.encodeToString(key, Base64.NO_WRAP);}/*** 加密** param content 需要加密的内容* param key 加密密码* return*/public static String encrypt(String content, String key) {return encrypt(content,key.getBytes());}public static String encrypt(String content, byte[] key) {try {//构造密钥SecretKeySpec skey new SecretKeySpec(key, utf-8);//创建初始向量iv用于指定密钥偏移量(可自行指定但必须为128位)因为AES是分组加密下一组的iv就用上一组加密的密文来充当IvParameterSpec iv new IvParameterSpec(key, 0, 16);//创建AES加密器Cipher cipher Cipher.getInstance(AES/CBC/PKCS5Padding);byte[] byteContent content.getBytes(StandardCharsets.UTF_8);//使用加密器的加密模式cipher.init(Cipher.ENCRYPT_MODE, skey, iv);// 加密byte[] result cipher.doFinal(byteContent);//使用BASE64对加密后的二进制数组进行编码return encode(result);} catch (Exception e) {e.printStackTrace();return content;}}/*** 解密* param content* param key* return*/public static String decrypt(String content, byte[] key) {try {SecretKeySpec skey new SecretKeySpec(key, utf-8);IvParameterSpec iv new IvParameterSpec(key, 0, 16);Cipher cipher Cipher.getInstance(AES/CBC/PKCS5Padding);//解密时使用加密器的解密模式// 初始化cipher.init(Cipher.DECRYPT_MODE, skey, iv);byte[] result cipher.doFinal(base64ToDecode(content));// 解密return new String(result);} catch (Exception e) {return content;}}
}
package com.tcssj.mbjmbimport android.os.Bundle
import android.os.Handler
import android.util.Log
import androidx.activity.ComponentActivity
import androidx.activity.compose.setContent
import androidx.compose.foundation.layout.fillMaxSize
import androidx.compose.material3.MaterialTheme
import androidx.compose.material3.Surface
import androidx.compose.material3.Text
import androidx.compose.runtime.Composable
import androidx.compose.ui.Modifier
import androidx.compose.ui.tooling.preview.Preview
import com.tcssj.mbjmb.ui.theme.MbjmbTheme
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.runBlocking
import okhttp3.Headers
import okhttp3.MediaType
import okhttp3.OkHttpClient
import okhttp3.Request
import okhttp3.RequestBody
import org.json.JSONObjectclass MainActivity : ComponentActivity() ,test {private val TAG MainActivitylateinit var text:Stringoverride fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)runBlocking(Dispatchers.IO) {val okHttpClientOkHttpClient()
// val buildokHttpClient.newBuilder()val jsonpostJSONObject()jsonpost.put(type,text)jsonpost.put(mobile,81991419936)val bodyRequestBody.create(MediaType.parse(application/json;charsetutf-8),AESUtil2.encrypt(jsonpost.toString(),AESUtil2.base64ToDecode(allWUzg1eFJ3ekpNQklUeQ)))val jsonJSONObject()json.put(sourceChannel,Orange)json.put(packageName,com.tcssj.mbjmb)json.put(adid,)json.put(version,12.0.0)json.put(uuId,)json.put(userId,)val request Request.Builder().url(http://47.101.194.189:10018/auth/v3.1/user/sendVerifiyCode).header(HCFQ,AESUtil2.encrypt(json.toString(), xDBrgJdnnY2w1Do7Ik6otonXQRgQyt46)).header(packageName,mbjmb).post(body).build()val response okHttpClient.newCall(request).execute()response.toString()textAESUtil2.decrypt(response.body().string(), AESUtil2.base64ToDecode(allWUzg1eFJ3ekpNQklUeQ))Log.i(TAG, onCreate: AESUtil2.decrypt(text, AESUtil2.base64ToDecode(allWUzg1eFJ3ekpNQklUeQ)))}setContent {MbjmbTheme {// A surface container using the background color from the themeSurface(modifier Modifier.fillMaxSize(),color MaterialTheme.colorScheme.background) {Greeting(name text)}}}}
}Composable
fun Greeting(name: String, modifier: Modifier Modifier) {Text(text $name!,modifier modifier)
}Preview(showBackground true)
Composable
fun GreetingPreview() {MbjmbTheme {Greeting(Android)}
}第一个问题的原因就是我们参数进行加密后有换行符号\n,怎么解决呢如下图划线的部分你如果是用的Default那就会报第一个错误你需要使用NO_WRAP 不生成换行符的。 第二个坑就是返回的也是加密后的乱码你需要拿回来解密的那你下图中就不能使用body.toString() 方法要用String()方法。我是怎么发现的我用apifox 工具如果你接口调试还没使用上拿走不谢还是要用这么个工具不然你来来回回启动app调试接口效率很低但你会懒的使用抗拒学新的人吗天性但你要克服调试接口的时候发现工具和android里面的返回结果不一致 因为看下图如果你用了toString 方法 message当时空的整个是空的框架加密的内容okhttp无法转换成它的结构那你就要用string拿到字符串自己解析。