在server.xml中增加下面的内容:

  1. ciphers="SSL_RSA_WITH_RC4_128_SHA"

下面是libcurl 的测试代码:

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4. #include <curl/curl.h>
  5. static size_t save_response_callback(void *buffer,size_t size,size_t count,void **response)
  6. {
  7. char * ptr = NULL;
  8. printf("buffer is %s\n",(char *)buffer);
  9. ptr =(char *) malloc(count*size + 4);
  10. memcpy(ptr,buffer,count*size);
  11. *response = ptr;
  12. return count;
  13. }
  14. int main(int argc,char *argv[])
  15. {
  16. CURL * curl;
  17. CURLcode res;
  18. char * response = NULL;
  19. if(argc !=2){
  20. printf("Usage:file<url>;\n");
  21. return;
  22. }
  23. //curl_global_init(CURL_GLOBAL_DEFAULT);
  24. curl = curl_easy_init();
  25. if(curl!=NULL){
  26. printf("Usage:file<%s>;\n",argv[1]);
  27. curl_easy_setopt(curl,CURLOPT_URL,argv[1]);
  28. curl_easy_setopt(curl,CURLOPT_WRITEFUNCTION,&save_response_callback);
  29. curl_easy_setopt(curl,CURLOPT_WRITEDATA,&response);
  30. curl_easy_setopt(curl,CURLOPT_COOKIESESSION,1L);
  31. curl_easy_setopt(curl,CURLOPT_COOKIEFILE,"/dev/null");
  32. curl_easy_setopt(curl,CURLOPT_SSL_VERIFYPEER,1);
  33. //curl_easy_setopt(curl,CURLOPT_CAPATH,"/etc/ssl/cert/");
  34. curl_easy_setopt(curl,CURLOPT_CAINFO,"ca-cert.pem");
  35. curl_easy_setopt(curl,CURLOPT_SSL_VERIFYHOST,1);
  36. curl_easy_setopt(curl,CURLOPT_VERBOSE,1L);
  37. curl_easy_setopt(curl,CURLOPT_TIMEOUT,30);
  38. #if 0
  39. /* 双向验证下面是客户端的CA*/
  40. //  curl_easy_setopt(curl,CURLOPT_CAPATH,"./");
  41. curl_easy_setopt(curl,CURLOPT_SSLCERT,"client-cert.pem");
  42. curl_easy_setopt(curl,CURLOPT_SSLCERTPASSWD,"password");
  43. curl_easy_setopt(curl,CURLOPT_SSLCERTTYPE,"PEM");
  44. curl_easy_setopt(curl,CURLOPT_SSLKEY,"client-key.pem");
  45. curl_easy_setopt(curl,CURLOPT_SSLKEYPASSWD,"password");
  46. curl_easy_setopt(curl,CURLOPT_SSLKEYTYPE,"PEM");
  47. #endif
  48. res = curl_easy_perform(curl);
  49. if(res != CURLE_OK){
  50. printf("curl_wasy_perform error = %s",curl_easy_strerror(res));
  51. }
  52. printf("response<%s>\n",response);
  53. curl_easy_cleanup(curl);
  54. }
  55. }

参考资料:

SSL证书制作:http://blog.chinaunix.net/uid-7591044-id-1742977.html 

libcurl使用认证证书 https认证的更多相关文章

  1. Https、OpenSSL自建CA证书及签发证书、nginx单向认证、双向认证及使用Java访问

    0.环境 本文的相关源码位于 https://github.com/dreamingodd/CA-generation-demo 必须安装nginx,必须安装openssl,(用apt-get upd ...

  2. 探究公钥、私钥、对称加密、非对称加密、hash加密、数字签名、数字证书、CA认证、https它们究竟是什么,它们分别解决了通信过程的哪些问题。

    一.准备 1. 角色:小白.美美.小黑. 2. 剧情:小白和美美在谈恋爱:小黑对美美求而不得.心生怨念,所以从中作梗. 3. 需求:小白要与美美需通过网络进行通信,联络感情,所以必须保证通信的安全性. ...

  3. java https单向认证(忽略认证)并支持http基本认证

    https单向认证(忽略认证)并支持http基本认证, 温馨提示 1,jar包要导入对 2,有匿名类编译要注意 3,欢迎提问,拿走不谢!背景知识 Https访问的相关知识中,主要分为单向验证和双向验证 ...

  4. AFNetworking之于https认证

    写在开头: 本来这篇内容准备写在AFNetworking到底做了什么?(三)中的,但是因为我想在三中完结这个系列,碍于篇幅所限.并且这一块内容独立性比较强,所以单独拎出来,写成一篇. 本文从源码的角度 ...

  5. AFNetworking 之于 https 认证

    写在开头: 本来这篇内容准备写在AFNetworking到底做了什么?(三)中的,但是因为我想在三中完结这个系列,碍于篇幅所限.并且这一块内容独立性比较强,所以单独拎出来,写成一篇. 本文从源码的角度 ...

  6. 【转】AFNetworking之于https认证

    转自:http://www.cocoachina.com/ios/20161220/18393.html 写在开头: 本来这篇内容准备写在AFNetworking到底做了什么?(三)中的,但是因为我想 ...

  7. Linux下Apache https认证

    参考:http://kyfxbl.iteye.com/blog/1910891 http://showerlee.blog.51cto.com/2047005/1266712 一.环境 httpd:A ...

  8. https认证

    HTTPS认证 说明 1. HTTPS协议的站点信息更加安全,同时可降低网站被劫持的风险,如网站同时存在HTTP和HTTPS站点,可使用本工具进行认证,便于百度搜索识别网站HTTP与HTTPS之间的对 ...

  9. Harbor配置https认证

    Harbor配置https认证由于Harbor不附带任何证书,它默认使用HTTP来提供注册表请求.但是,强烈建议为任何生产环境启用安全性.因为测试使用,使用自签名证书: 1.创建CA证书 首先创建个目 ...

随机推荐

  1. 【前端】用javaScript实现实现一个球池的效果

    ballPool 用javaScript实现实现一个球池的效果,实现效果如下所示: 动图: 截图: HTML代码: <!DOCTYPE html> <html > <he ...

  2. journalctl 工具使用

    在Systemd出现之前,Linux系统及各应用的日志都是分别管理的,Systemd开始统一管理了所有Unit的启动日志,这样带来的好处就是可以只用一个 journalctl命令,查看所有内核和应用的 ...

  3. openwrt下定义软件包的依赖关系类型

    在openwrt下软件包的依赖关系由DEPENDS:=来指定 第一种依赖关系类型为只有将依赖的软件包手动选上,当前的软件包就会自动被选中,用法为DEPENDS:=package_name 第二种依赖关 ...

  4. intellij idea rearrange code

        reformat code的时候,无法将filed放在method前边,很恶心. 那么先去

  5. RocketMQ 自己的整理和理解

    每个人的想法不同, RocketMQ 介绍的时候就说 是阿里从他们使用的上 解耦出来 近一步简化 便捷的 目的当然是 让其能快速入手和开发 如果不是在项目设计层面上 只是使用的话 从Git上下载该项目 ...

  6. windows组策略屏蔽

    点“IP安全策略,在本地机器”——>创建IP安全策略---->下一步---->名称随便写,如输入阻止,然后一直点下一步,出现提示点是,一直到完成,这个时候就创建了一个名为“阻止”的策 ...

  7. POJ 2186 Popular Cows(强连通分量Kosaraju)

    http://poj.org/problem?id=2186 题意: 一个有向图,求出点的个数(任意点可达). 思路: Kosaraju算法的第一次dfs是后序遍历,而第二次遍历时遍历它的反向图,从标 ...

  8. 在 Spark 中使用 IPython Notebook

    本文是从 IPython Notebook 转化而来,效果没有本来那么好. 主要为体验 IPython Notebook.至于题目,改成<在 IPython Notebook 中使用 Spark ...

  9. 讲一下numpy的矩阵特征值分解与奇异值分解

    1.特征值分解 主要还是调包: from numpy.linalg import eig 特征值分解:  A = P*B*PT  当然也可以写成 A = QT*B*Q  其中B为对角元为A的特征值的对 ...

  10. Memcached incr 与 decr 命令

    Memcached incr 与 decr 命令用于对已存在的 key(键) 的数字值进行自增或自减操作. incr 与 decr 命令操作的数据必须是十进制的32位无符号整数. 如果 key 不存在 ...