在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. MR案例:小文件处理方案

    HDFS被设计来存储大文件,而有时候会有大量的小文件生成,造成NameNode资源的浪费,同时也影响MapReduce的处理效率.有哪些方案可以合并这些小文件,或者提高处理小文件的效率呢? 1). 所 ...

  2. 批处理命令 For循环命令详解!

    批处理for命令详解FOR这条命令基本上都被用来处理文本,但还有其他一些好用的功能!看看他的基本格式(这里我引用的是批处理中的格式,直接在命令行只需要一个%号)FOR 参数 %%变量名 IN (相关文 ...

  3. hibernate关联非主键注解配置

    现在有两张表:一张t_s_user用户表和t_s_user_serial_number用户序号表 CREATE TABLE `t_s_user` ( `id` ) NOT NULL, `email` ...

  4. OAuth Implementation for ASP.NET Web API using Microsoft Owin.

    http://blog.geveo.com/OAuth-Implementation-for-WebAPI2 OAuth is an open standard for token based aut ...

  5. caffe2+cuda+Ubuntu16.04(u盘安装)

    安装caffe2 预先准备.安装gflags及autoconf及GLOG https://github.com/caffe2/caffe2/issues/1810 一.下载源代码通过网盘 https: ...

  6. 使用FireFox插件RESTClient工具POST方法?

    下面尝试用Firefox的restclient,来调取api 当然需要打开火狐浏览器安装restclient的插件https://addons.mozilla.org/en-US/firefox/ad ...

  7. Select级联菜单,用Ajax获取Json绑定下拉框(jQuery)

    需求类似这样  ↓ ↓ ↓   -->    菜单A发生变化,动态取数据填充下拉菜单B. JS代码如下: <script type="text/javascript"& ...

  8. spring 或 springboot统一异常处理

    spring 或 springboot统一异常处理https://blog.csdn.net/xzmeasy/article/details/76150370 一,本文介绍spring MVC的自定义 ...

  9. ubuntu如何U盘启 动制作

    先到出 U盘的位置, 方法有很多,terminal 用root权限,采用fdisk -f 命令 unmount /dev/sdb -I //U盘拨出 sdb为U盘挂载的位置 mkfs.fat /dev ...

  10. Memcached stats slabs 命令

    Memcached stats slabs 命令用于显示各个slab的信息,包括chunk的大小.数目.使用情况等. 语法: stats slabs 命令的基本语法格式如下: stats slabs ...