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;
}