«August 2025»
12
3456789
10111213141516
17181920212223
24252627282930
31


公告

本站技术贴除标明为“原创”的之外,其余均为网上转载,文中我会尽量保留原作者姓名,若有侵权请与我联系,我将第一时间做出修改。谢谢!

             ——既瑜


天气预报(南京)


我的分类(专题)

首页(183)
【趣味文摘】(22)
【五子连珠】(13)
【技术文档】(136)
【电脑技术】(6)
【疑难问题】(1)
【我的心情】(5)


最新日志
花语(中英文对照版)
各种花的花语
NTFS格式的7个精彩问答(pconli
童言无忌,有趣得一蹋
给MM修电脑的三个步骤[转载]
J2EE 面试题综合
JAVA编程规则
[转] P2P之UDP穿透NAT的原理与
[转]词法分析器
文件加密技术
一个让人发狂的PI求解C程序
[转]直线生成算法之DDA
[转]利用内核对象----互斥量实现应用
[转]如何正确的计算文件收发进度
双机调试VC程序
[转]分治法优化大整数乘法 C++实现
浮点数值的内存结构
[转]双链表实现大整数的加法与乘法[VC
拜占廷将军问题[转]
某人的挂QQ的程序源代码,虽然没用了,拿

最新回复
回复:vc中的CString的操作
回复:[转]分治法优化大整数乘法 C++
回复:[转]分治法优化大整数乘法 C++
回复:花语(中英文对照版)
回复:基本排序算法比较与选择[转载]
回复:c++中强制类型转换操作符小结
回复:c++中强制类型转换操作符小结
何必那么执着于是大头猫还是愤怒的小鸟,淡
回复:浮点数值的内存结构
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:32位位图到24位位图的转换
dren, ages 16 and 20
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:花语(中英文对照版)
回复:各种花的花语

留言板
签写新留言

不是0-1背包喔
桂花的花语``
谢谢
提议
提议

统计
blog名称:★既瑜★
日志总数:183
评论数量:636
留言数量:-25
访问次数:1406208
建立时间:2005年3月12日

链接


http://www.nju.edu.cn
http://bbs.nju.edu.cn 
http://www.t7-online.com
http://www.csdn.net
http://www.91f.net
http://www.crsky.com
我的MSN BLOG 

联系我

  OICQ:215768265
  njucs2001@hotmail.com
  erichoo1982@gmail.com

 

W3CHINA Blog首页    管理页面    写新日志    退出


[【技术文档】]用crypto api 实现公钥加密,私钥解密
既瑜(224499) 发表于 2005/7/21 9:55:21

用crypto api 实现公钥加密,私钥解密     选择自 w9521423 的 Blog    终于使用Microsoft Enhanced Cryptographic Provider v1.0 实现了公钥加密和解密,但SafeSign CSP Version 1.0不能,不知为什么,有高手能解答吗?另外dwBufLen 怎样计算才好,我取100,出编号234错,便取了200。以下程序在VS2003下调试成功#include "stdafx.h"#include <stdio.h>#include <windows.h>#include <wincrypt.h>void HandleError(char *s);#define SA_SIGN_PROV       "SafeSign CSP Version 1.0"int _tmain(int argc, _TCHAR* argv[]){     HCRYPTPROV hCryptProv;   HCRYPTKEY hXchgKey; //交换密钥     BYTE pbData[1000];     DWORD cbData;     printf("A cryptographic provider will acquired. \n");     char ch;     //--------------------------------------------------------------------          //访问CSP     if(CryptAcquireContext(           &hCryptProv,            NULL,                        //NULL表示使用默认密钥容器,默认密钥容器名为用户登陆名           MS_ENHANCED_PROV ,//SA_SIGN_PROV ,            //SA_SIGN_PROV ,            PROV_RSA_FULL,            0))     {           printf("A cryptographic provider has been acquired. \n");     }     else     {      printf("Error in get cryptographic provider h. \n");           }  //得到CSP参数     cbData = 10000;  if(CryptGetProvParam(          hCryptProv,          PP_NAME,          pbData,          &cbData,            CRYPT_FIRST ))  {      printf("CryptGetProvParam succeeded.\n");      printf("Provider name: %s\n", pbData);                          }  else  {    printf("Error reading CSP name. \n");    //exit(1);  }//得到用户的密钥对     if(CryptGetUserKey(      hCryptProv,       AT_KEYEXCHANGE,       &hXchgKey))  {    printf("The user exchange key pair has been retrieved. \n");    BOOL bResult;      DWORD dwSecretLen;    char bSecret[100]="I LOVE YOU";   //改了    dwSecretLen=strlen((char *) bSecret)+1;//使用公钥加密                if(!CryptEncrypt(        hXchgKey,         // 之前获得的密鈅对象        0,           // 不散列数据        TRUE,         // 最后的还是缓冲的数据        0,           // 必须置0        (BYTE*)bSecret,       // 数据缓冲区        &dwSecretLen,       // 数据尺寸        200)     // 数据块尺寸          )        {             printf("Error during CryptEncrypt. \n");       HandleError("Error during CryptEncrypt. \n");     }         else              {                    printf("The CRYPTENCRYPT SUCESS. \n");          printf("Encrypt text:%s\n",bSecret);              }//---------------------------------------------------------//使用私钥解密              if(!CryptDecrypt(hXchgKey,0,TRUE,0,(BYTE*)bSecret,&dwSecretLen))//改了      {          HandleError("Error during decrypt. \n");                             }       else        { printf("CryptDecrypt sucess");        printf("Decrypt text:%s\n",bSecret);        ch=getchar();        }  }           getchar();     return 0;}void HandleError(char *s){  fprintf(stderr,"An error occurred in running the program. \n");  fprintf(stderr,"%s\n",s);  fprintf(stderr, "Error number %d.\n", GetLastError());        fprintf(stderr, "Program terminating. \n");     getchar();  exit(1);} // End of HandleError 作者Blog:http://blog.csdn.net/w9521423/

阅读全文(3781) | 回复(2) | 编辑 | 精华

回复:用crypto api 实现公钥加密,私钥解密
既瑜(224499)发表评论于2005/8/26 9:22:36

这个不太了解

个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

回复:用crypto api 实现公钥加密,私钥解密
rediscover(游客)发表评论于2005/8/26 8:44:15

为什么在win2000 加密后的文件,在windos 2003环境下不能还原? 谢谢! rediscover@mail.china.com
个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除

» 1 »

发表评论:
昵称:
密码:
主页:
标题:
验证码:  (不区分大小写,请仔细填写,输错需重写评论内容!)

站点首页 | 联系我们 | 博客注册 | 博客登陆

Sponsored By W3CHINA
W3CHINA Blog 0.8 Processed in 0.275 second(s), page refreshed 144765860 times.
《全国人大常委会关于维护互联网安全的决定》  《计算机信息网络国际联网安全保护管理办法》
苏ICP备05006046号