首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >CryptoSwift AES128 128-CBC与Swift

CryptoSwift AES128 128-CBC与Swift
EN

Stack Overflow用户
提问于 2016-02-25 08:10:14
回答 1查看 6.9K关注 0票数 1

在解密AES128CBC加密的JSON时,我得到了这个错误:

断言失败:块大小和初始化向量必须相同长度!:iOS/CryptoSwift/Sources/CryptoSwift/AES.swift,第97行的文件#####

我使用的是CryptoSwift框架和最新的Xcode。

我的方法:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
func aes128(key: String, iv: String) throws -> String?{
        if let aes: AES = try AES(key: key, iv: iv, blockMode: .CBC){
            if let encrypted: [UInt8] = try aes.encrypt([UInt8](self.utf8), padding: PKCS7()){
                return String(data: NSData.withBytes(encrypted), encoding: NSUTF8StringEncoding)
            }
        }

        return nil
}

呼叫:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
do{
    print(try dataStr.aes128("8e0c0e73f97f2eb386ad75ba86051334", iv: "aa17ffc4ea4b1eac8fa0b56872f34e5f"))   
}catch{

}
EN

回答 1

Stack Overflow用户

发布于 2016-02-25 11:29:35

我的方法:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
func aes128(key: [UInt8], iv: [UInt8]) throws -> String?{
    let data = NSData(base64EncodedString: self, options: NSDataBase64DecodingOptions(rawValue: 0))
    let dec = try AES(key: key, iv: iv, blockMode:.CBC).decrypt(data!.arrayOfBytes(), padding: PKCS7())
    let decData = NSData(bytes: dec, length: Int(dec.count))
    let result = NSString(data: decData, encoding: NSUTF8StringEncoding)
    return String(result!)
}

呼吁:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
do{
    let secret: [UInt8] = self.getAuthSecret(.LoginSecret)!.byte
    let ivSlice = secret[0..<16]
    let ivArray = Array<UInt8>(ivSlice)

    let keySlice = secret[16..<32]
    let keyArray = Array<UInt8>(keySlice)

    print(try dataStr.aes128(keyArray, iv: ivArray))
}catch{

}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35632521

复制
相关文章
python aes128加密
1.代码 class Aes_ECB(object): def __init__(self): self.key = 'XXXXXXXXXXX' #秘钥 self.MODE = AES.MODE_ECB self.BS = AES.block_size self.pad = lambda s: s + (self.BS - len(s) % self.BS) * chr(self.BS - len(s) % self.BS)
小小咸鱼YwY
2020/06/19
8820
Swift String 与 NSString
String 是结构体, 值类型, NSString 是类, 引用类型. 通常, 没必要使用 NSString 类, 除非你要使用一些特有方法, 例如使用 pathExtension 属性
赵哥窟
2020/08/11
7670
iOS开发常用之代码安全与密码
代码安全与密码 ios-class-guard - 一个用于混淆iOS的类名,方法名以及变量名的开源库 - 有人反映编译出来的app运行不了。 “保护iOS应用程序”:文章系统地介绍了如何保护iOS程序的代码安全,防止反汇编分析。 fishhook - fishhook是Facebook开源的一个可以hook系统方法的工具。 GesturePassword - 一个iOS手势密码功能实现,iPad / iPhone都可以用,没有使用图片,里面可以通过查看自己添加.keychain做的数据持久化
GuangdongQi
2018/12/14
6820
OC framework 与 Swift 混编
在模块化,组件化的热潮下,不管是真的因为业务复杂或者是对于未来业务的提前规划还是只是被这股热潮裹挟着,我们手上不少项目都已经完成了组件化或者正在实现。当历史模块需要修改时,直接使用OC进行是一个很正确的选择,但是某些时候,引入 Swift 也是其中一个选择。
韦弦zhy
2023/10/16
1.7K0
OC framework 与 Swift 混编
Carthage使用
之前一直用CocoaPods,这次做编译时间优化时,把某些Pod依赖的库改为了Carthage依赖的,这里记录一下Carthage的使用。
莫空9081
2023/10/16
2450
Carthage使用
Swift 宏定义与代码标记
写Objective-C的时候常常会用到各种宏定义,但是Swift中貌似没有宏的这种定义,更多的是通过全局常量或者全局函数来实现这一效果.我们只需要建立一个文件(假设为Const.swift),把想用的定义在里面,无须导入头文件什么的,就可以在全局用啦.
Originalee
2018/08/30
2.3K0
窥探Swift之数组与字典
说到数组和字典,只要是编过程的小伙伴并不陌生。在Swift中的数组与字典也有着一些让人眼前一亮的特性,今天的博客就来窥探一下Swift中的Array和Dictionary。还是沿袭之前的风格,在介绍Swift中的数组时,我们会对比一下ObjC中的数组和字典,因为ObjC也是iOS开发的主要语言不是。无论是简单还是复杂的程序,数组和字典的用处还是比较多的,这两者虽然是Swift的基础内容,但是也不失其重要性。关于Objc的集合类请参考之前的博客《Objective-C中的集合类》。 一、Swift中的数组(A
lizelu
2018/01/11
1.9K0
窥探Swift之数组与字典
Swift与JS通过WKWebView互调
创建WKWebView lazy var webView: WKWebView = { // 创建WKPreferences let preferences = WKPreferences() // 开启js preferences.javaScriptEnabled = true // 创建WKWebViewConfiguration let configuration = WKWebViewConfiguration() // 设置WKWebVie
YungFan
2020/12/25
2.7K0
swift 与现有OC项目混编
最近在玩vapor,于是借助公司的服务器划分出来50G空间分配8G内存做了个App日志上传的server,顺便使用swift将日志收集集成到现有OC项目中…… 不得不说,swift与OC集成还是有一点小小麻烦:
大话swift
2019/07/04
1.3K0
Ceph Swift Api 配置与使用(三)
在 ceph 的使用上, 互联网大规模的文件场景下, fs 并不能满足生产的使用要求, rados 本地化操作也不便于服务的接入与使用, 这里我们就要采用 Ceph Swift Api 来实现文件的存储管理。
Lansonli
2022/04/11
8940
Ceph Swift Api 配置与使用(三)
iOS-Swift 结构体与类
在 Swift 的标准库中,绝大多数的公开类型都是结构体,而枚举和类只占很小一部分。比如 Bool、Int、Double、 String、Array、Dictionary 等常见类型都是结构体。
CC老师
2022/01/14
1.4K0
iOS-Swift 结构体与类
iOS 开发之路(AES/DES加密实现) 三
  最近接触的这个项目由于以前服务器上用的是DES/CBC/PKCS5Padding加密方式,为了让在iOS上的加密结果与服务器端保持一致,我做了很多尝试,现在分享给大家。PS:现在不推荐用DES了,只是服务器端不能随便改,别的项目平台有依赖。
从今若
2019/09/19
1.3K0
Swift基础 关于Swift
Swift 是编写软件的绝佳方式,无论是手机、台式机、服务器还是任何其他运行代码的内容。这是一种安全、快速和互动的编程语言,它结合了现代语言思维的最佳与更广泛的苹果工程文化的智慧以及开源社区的各种贡献。编译器针对性能进行了优化,语言也针对开发进行了优化,同时不影响两者。
郭顺发
2023/07/17
950
Swift 网络请求数据与解析
一: Swift 网络数据请求与处理最常用第三方  又有时间出来装天才了,还是在学swift,从中又发现一些问题,这两天上网找博客看问题弄的真的心都累。博客一篇写出来,好多就直接照抄,就没有实质性的把问题解决了,只是在发表的博客数量上 + 1 !!真心没意思。。     看看在Swift中是在怎样请求数据,解析数据加载图片这些的,也使我们最基本最常见的用法了,先说说这几个三方库:      第一个: Alamofire  (它的原作者就是AFNetworking的原作者,这个就不多说了,你要知道AFNet
Mr.RisingSun
2018/01/09
2.5K0
Swift 网络请求数据与解析
Swift进阶一:Swift简介
Swift语言引入了协议、协议的扩展、泛型等新特性,因此使用Swift语言可以很好地面向协议编程;Swift语言将函数和闭包提升为语言的一等公民,函数可以作为一个变量、可以作为其他函数的参数、作为其他函数的返回值等来传递,所以我们可以使用Swift来进行函数式编程,另外Swift也提供了很多高阶函数来辅助我们进行函数式编程;Swift也提供了属性的权限限定等面向对象的基础设置,因此在Swift中也可以面向对象来编程。
拉维
2020/07/09
2.8K0
Swift进阶一:Swift简介
Swift入门:多态性与类型转换
因为类可以相互继承(例如CountrySinger可以从Singer继承),这意味着一个类实际上是另一个类的超集:B类拥有A类所拥有的所有东西,还有一些额外的东西。这反过来意味着你可以把B当作B型或者A型,这取决于你的需要。
韦弦zhy
2020/03/19
9590
Swift macOS开发与Core Data,CloudKit开篇
喜欢将自己称之为创造者,也很庆幸能用自己的既能创造点东西出来,花花世界可爱的技术太多了,就连单单写个App就有着各种要花缭乱的法子,webview的,混合的,原生的……,谁不想用最小的力气写出最好的作品呢。
小刀c
2022/08/16
4410
27.Swift学习之与OC混编
在目前iOS开发语言从Objective-C到Swift的过渡时期,开发中难免会碰到两种语言同时存在的情况,如果在同一个项目中,两种语言并存,那么该项目就是一个混合项目。在混合项目中,就会存在语言相互调用的情况,那么一个是上世纪的“老人”,一个是初出茅庐的“少年”,它们的沟通是存在障碍的,如何才能在一个项目中让两种语言可以相互调用呢?Apple给我们做好了“桥接”工作,但是在Objective-C的项目中调用Swift与在Swift项目中调用Objective-C,处理的方式是不一样的,下面来进行一个简单的介绍。
YungFan
2018/12/26
1.2K0
Swift
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/118291.html原文链接:https://javaforall.cn
全栈程序员站长
2022/07/13
2.1K0
点击加载更多

相似问题

使用AES128 CTR模式的CryptoSwift -错误计数器增量?

16

CryptoSwift不能使用swift 2

220

CryptoSwift与目标C

12

swift中的AES128加密

31

SWIFT4.0的CryptoSwift Lib安装失败

21
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文