博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
iOS编程安全之路-RSA签名与验签
阅读量:4113 次
发布时间:2019-05-25

本文共 1668 字,大约阅读时间需要 5 分钟。

RSA作为最主流的加解密与验签算法,iOS当然少不
签名

unsigned char *rsaPKCS1SignData(const unsigned char *src,int src_len,unsigned char*pri_key,int pri_key_len, int *dst_len){

        unsigned char *pri_pem =  formatPem(pri_key, PEM_FORMAT_PRIVATEKEY);

        

        BIO *bio_private = NULL;

        RSA *rsa_private = NULL;

        bio_private = BIO_new(BIO_s_mem());

        

        BIO_write(bio_private, pri_pem, strlen((const char *)pri_pem));

        unsigned char pwd[] = "";

        rsa_private = PEM_read_bio_RSAPrivateKey(bio_private, NULL, (pem_password_cb *)pwd,NULL);

        

        

        EVP_PKEY *key = EVP_PKEY_new();

        int err = EVP_PKEY_assign_RSA(key,rsa_private);

        

        int size=0;

        

        if (err) {

            size = EVP_PKEY_size(key);

        }

        

        EVP_MD_CTX *ctx = EVP_MD_CTX_create();

        EVP_MD_CTX_init(ctx);

        

        EVP_SignInit_ex(ctx,EVP_sha1() , NULL);

        

        

        EVP_SignUpdate(ctx, src,src_len);

        

        unsigned char *md=(unsigned char *)malloc(size);

        unsigned int len = 0;

        

        EVP_SignFinal(ctx, md, &len, key);

        *dst_len = len;

        

        EVP_PKEY_free(key);

        EVP_MD_CTX_cleanup(ctx);

        return md;

    }

验签

bool 

    rsaVerify(const unsigned char *src,int src_len,unsigned char *sig,unsigned int sigl_len,unsigned char *pub_key,int pub_key_len){

        

        unsigned char *pub_pem =  formatPem(pub_key, PEM_FORMAT_PUBKEY);

        

        BIO *bio_public = NULL;

        

        bio_public = BIO_new(BIO_s_mem());

        

        BIO_write(bio_public, pub_pem, strlen((const char *)pub_pem));

        

        EVP_PKEY *key=NULL;

        PEM_read_bio_PUBKEY(bio_public, &key, NULLNULL);

    

        

        int size=0;

        

        if (key) {

            size = EVP_PKEY_size(key);

        }

        

        EVP_MD_CTX *ctx = EVP_MD_CTX_create();

              EVP_MD_CTX_init(ctx);

        

        EVP_VerifyInit_ex(ctx, EVP_sha1(), NULL);

        

        

        EVP_VerifyUpdate(ctx, src,src_len);

        

        

        

        int suc = EVP_VerifyFinal(ctx, sig, sigl_len, key);

        

        

        EVP_PKEY_free(key);

        EVP_MD_CTX_cleanup(ctx);

        if (suc == 1) {

            return true;

        }

        else

            return false;

    }

转载地址:http://vrwpi.baihongyu.com/

你可能感兴趣的文章
微信小程序中使用npm过程中提示:npm WARN saveError ENOENT: no such file or directory
查看>>
Xcode 11 报错,提示libstdc++.6 缺失,解决方案
查看>>
idea的安装以及简单使用
查看>>
Windows mysql 安装
查看>>
python循环语句与C语言的区别
查看>>
Vue项目中使用img图片和background背景图的使用方法
查看>>
vue 项目中图片选择路径位置static 或 assets区别
查看>>
vue项目打包后无法运行报错空白页面
查看>>
Vue 解决部署到服务器后或者build之后Element UI图标不显示问题(404错误)
查看>>
element-ui全局自定义主题
查看>>
facebook库runtime.js
查看>>
vue2.* 中 使用socket.io
查看>>
openlayers安装引用
查看>>
js报错显示subString/subStr is not a function
查看>>
高德地图js API实现鼠标悬浮于点标记时弹出信息窗体显示详情,点击点标记放大地图操作
查看>>
初始化VUE项目报错
查看>>
vue项目使用安装sass
查看>>
HTTP和HttpServletRequest 要点
查看>>
在osg场景中使用GLSL语言——一个例子
查看>>
关于无线PCB中 中50欧姆的特性阻抗的注意事项
查看>>