社区
C#
帖子详情
加密解密的时候的错误。Base-64 字符数组的无效长度。如果我加密的字符串很长的话,解密的时候,会出现这个错误,怎么解决?
afantict
2008-03-07 04:46:55
加密解密的时候的错误。Base-64 字符数组的无效长度。如果我加密的字符串很长的话,解密的时候,会出现这个错误,怎么解决?
...全文
2921
7
打赏
收藏
加密解密的时候的错误。Base-64 字符数组的无效长度。如果我加密的字符串很长的话,解密的时候,会出现这个错误,怎么解决?
加密解密的时候的错误。Base-64 字符数组的无效长度。如果我加密的字符串很长的话,解密的时候,会出现这个错误,怎么解决?
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
7 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
afantict
2008-03-08
打赏
举报
回复
你要是用我的代码加密aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa的话,然后再解密的话,没有问题吗?
我这边有问题。
lake_cx
2008-03-08
打赏
举报
回复
没问题,你的错误不是出在这,你再好好找一找
加密后是:
MpyjpbgslE+G+cL0ptwksPN8v+lx2UMGEalchC46oDyL0PpAOlFrMdoOqV63In8cN38uvle6XtDE5OW9ZHkXk9TQEPMc+RBLbsR3uONwFdhWa5vBooVDdByWVf9gu1YMII3LQ70Dj3FK/UW2wEyZPMPPrB4dVazS1pfDBNiYqIJWlD7RntsNp6Cha+ucWTJ/OhMMRTPuEZ/4A2fF/rrKszLxC5RVV/F6dBSzdpyfCSdk4PIAYYs29CtNjUoGQDOC4pXa/v2NKXmDxVFPQDyJBytNltGFNfs3tryTmbGGSyavb7yiLjYXa+hbinWaIRCNjcKLGOSEzUXXS6L5cMKqqAYqHbUlFQHg4/IVm9l2PDKg9dJUzD/iDRwBR4R7ZdMCgtwS0y/3JYSOlEn5JWghvEp5kEUT3/UmMmWcpNOt7pwCpEyNKGEv1QPVEG6kWs+LZm6WvnEnCHS2mLqv9hG1I5mnlmPUWBamAY9ZIYNbsnd2azzrxG3XASo3DTVef9qEwNlApqG/DGm1PaBDQfrmooUypDnGWM8vquU6G2/QElD8JAnbjmyBpV4RMpi7gCreyDXusKUJxOd4T6CC4jQ5ISYGHPUtoqalhPkqTHi2JeIkFxYKO/SSDlNqJPpGSCuEi3+1zaUOFPz2Djf5x8aj6eEHAkrANqIYpe70KykFMsNEbgjxELnqrV6FjkzMH/1//27EEs3WUubHsIpp3FiYcGaCq0IigOGMPdpXQQ4JviiKQfa+wClSA1gIBVQhhNXTqEP+x4Yw2Xw6EA03UDtjaiEwgJBX7osuIecXfVWDV8vUqKCZ4c270puDIbWAqGjHjR+aVSoB5xTXDPQSqLYFVcQQZdiDGwzxuviWsvaBed1Nhx/DkqyXUta5mKBzN3cK5ovGS5RMnsCiKQueOGgn4Q87jFrE1Jgz/TFT2vb6ctSGaJrnh7/YZQ==
lake_cx
2008-03-07
打赏
举报
回复
我试过了你的代码,没有问题,你需要找找,在base64编码后的字符串是不是在什么地方被改变过,例如弄个全局的存着编码后的,然后在你解码的时候先比较一下
lake_cx
2008-03-07
打赏
举报
回复
他是说Base64编码后的字符串中不能有回车什么的,当然,编码后是绝对不会有的,除非你在字符串传送中无意给加上了。
afantict
2008-03-07
打赏
举报
回复
我把我的代码贴出来。在解密函数的byte[] inputByteArray = Convert.FromBase64String(strToDecrypt);的地方出错。
确实字符串里面有换行符号之类的,不可以吗?
我加密的是richtextbox里面的东西,里面需要有换行符。
如果我不用Convert.FromBase64String这个函数的话,怎么才能byte和string之间进行转换?
大家帮帮忙
public static byte[] KEY = { 100, 110, 120, 130, 100, 110, 120, 130 };
public static byte[] IV = { 100, 110, 120, 130, 100, 110, 120, 130 };
public static string EncryptString(string strToEncrypt)
{
try
{
DESCryptoServiceProvider des = new DESCryptoServiceProvider();
byte[] inputByteArray = Encoding.UTF8.GetBytes(strToEncrypt);
MemoryStream ms = new MemoryStream();
CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(KEY, IV), CryptoStreamMode.Write);
cs.Write(inputByteArray, 0, inputByteArray.Length);
cs.FlushFinalBlock();
string strResult = Convert.ToBase64String(ms.ToArray());
cs.Close();
ms.Close();
return strResult;
}
catch (Exception e)
{
throw e;
}
}
public static string DecryptString(string strToDecrypt)
{
try
{
DESCryptoServiceProvider des = new DESCryptoServiceProvider();
byte[] inputByteArray = Convert.FromBase64String(strToDecrypt);
MemoryStream ms = new MemoryStream();
CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(KEY, IV), CryptoStreamMode.Write);
cs.Write(inputByteArray, 0, inputByteArray.Length);
cs.FlushFinalBlock();
ms.Close();
cs.Close();
return Encoding.UTF8.GetString(ms.ToArray());
}
catch (Exception e)
{
throw e;
}
}
whoami333
2008-03-07
打赏
举报
回复
看看你要还愿的字符串的末尾是否有\r\n等乱七八糟的东西,干掉再试一下。
lake_cx
2008-03-07
打赏
举报
回复
应该是原串不对,我记得好像base64的编码字符串长度是4的倍数还是怎么的(反正有规则),报这个错就是因为你的原串的长度不符合规范,肯定错了,它懒得给你解码了。
RSA
加密
解密
错误
:
Base-
64
字符
数组
的
无效
长
度
RSA
加密
解密
错误
:
Base-
64
字符
数组
的
无效
长
度
文章1.程序中实现了这样一个功能,将一个对象序列化后,作为参数传递给另一个页面,这个页面得到参数并反序列化后还原此对象,但是在运行时有时正常,有时
出现
“
base-
64
字符
数组
的
无效
长
度
”的
错误
提示。 在网上查找资料,都是说在使用Convert.ToBase64String()方法对
字符
串进行Base64编码时,需要使...
Base-
64
字符
数组
的
无效
长
度
在使用 System.Convert.FromBase64String
解密
时
会
报异常:
Base-
64
字符
数组
的
无效
长
度
原理:
加密
字符
串中的加好“+”在传参时
会
变成空格“ ”,所以在
解密
时
字符
串就
无效
了 例如:
加密
字符
串:dN8b8FHDK6lEz2uneeUZk+O/rrHBzaWT 传参后变成:dN8b8FHDK6lEz2uneeUZk O/rrHBzaWT
解密
时:不...
解决
“
Base-
64
字符
数组
的
无效
长
度
” 的问题
这两天做一个视频分享的模块,有一个功能是解析地址栏中的
加密
字符
串.实际使用过程中发现了"
Base-
64
字符
数组
的
无效
长
度
"的问题。后来分析才知道是由于地址栏中的
字符
"+"没有正确解析导致的。 using System;using System.Data;using System.Configuration;using System.Collections;using System.We
DES
解密
时“
Base-
64
字符
数组
的
无效
长
度
”
在使用Convert.ToBase64String()对
字符
串进行Base64编码时,注意的几点: 例:string s = "Hello"; byte[] bytes = Convert.FromBase64String(s); 以上代码在运行时
会
抛出FormatException异常.提示为:
Base-
64
字符
数组
的
无效
长
度
原因:当Convert.FromBase64String方法的参数s的
长
度
小于 4 或不是 4 的偶数倍时,将
会
抛出FormatException。
AES
解密
报
Base-
64
字符
数组
的
无效
长
度
理论不说了,主要说怎么
解决
。 该类问题 主要存在于 编码解码的问题。 由于 在传输过程中,将
字符
串中的 “+”,编码为 空格,而在解码时,并没有将 空格 解码为 +,故而应该在传输前,手动将 “+”进行编码 方法如下: string.replace("+","%2B"); 如图所示 知乎:https://zhuanlan.zhihu.com/albertwang ...
C#
110,571
社区成员
642,565
社区内容
发帖
与我相关
我的任务
C#
.NET技术 C#
复制链接
扫一扫
分享
社区描述
.NET技术 C#
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
让您成为最强悍的C#开发者
试试用AI创作助手写篇文章吧
+ 用AI写文章