默认情况下ssl模块并未被安装,如果要使用该模块则需要在编译时指定–with-http_ssl_module参数,安装模块依赖于OpenSSL库和一些引用文件,通常这些文件并不在同一个软件包中。通常这个文件名类似libssl-dev。

生成证书

可以通过以下步骤生成一个简单的证书:
首先,进入你想创建证书和私钥的目录,例如:

  1. $ cd /usr/local/nginx/conf

创建服务器私钥,命令会让你输入一个口令:

  1. $ openssl genrsa -des3 -out server.key 1024

创建签名请求的证书(CSR):

  1. $ openssl req -new -key server.key -out server.csr

在加载SSL支持的Nginx并使用上述私钥时除去必须的口令:

  1. $ cp server.key server.key.org
  2. $ openssl rsa -in server.key.org -out server.key

配置nginx

最后标记证书使用上述私钥和CSR:

  1. $ openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt

修改Nginx配置文件,让其包含新标记的证书和私钥:

  1. server {
  2. server_name YOUR_DOMAINNAME_HERE;
  3. listen 443;
  4. ssl on;
  5. ssl_certificate /usr/local/nginx/conf/server.crt;
  6. ssl_certificate_key /usr/local/nginx/conf/server.key;
  7. }

重启nginx。
这样就可以通过以下方式访问:

https://YOUR_DOMAINNAME_HERE

另外还可以加入如下代码实现80端口重定向到443IT人乐园

  1. server {
  2. listen 80;
  3. server_name ww.centos.bz;
  4. rewrite ^(.*) https://$server_name$1 permanent;
  5. }

转载请注明文章来源:http://www.centos.bz/2011/12/nginx-ssl-https-support/

最新文章

  1. Python3.5 day3作业一:实现简单的shell sed替换功能
  2. eclispe常用快捷键
  3. POJ 1637 Sightseeing tour (混合图欧拉路判定)
  4. Winform知识点
  5. 1029c语言文法
  6. Objective-C(二、类和对象)
  7. solr5.5教程-schema.xml部分配置
  8. java 基础知识十 继承和多态
  9. js加强版图片轮播
  10. FFmpeg AVPacket
  11. 关于利用maven搭建ssm的博客,我们一起来探讨下问的最多的问题
  12. Spring Security(三十三):10.3 Password Encoding
  13. 【2018.08.13 C与C++基础】网络通信:阻塞与非阻塞socket的基本概念及简单实现
  14. hibernate框架学习之增删改查helloworld
  15. Git和Github的基本操作
  16. Quartz.NET的简单任务管理类
  17. spring boot(十七)上传文件
  18. PageAdmin环境配置要求
  19. EasyUI----DataGrid行明细增删改操作
  20. perl语言入门总结-第4章-子程序

热门文章

  1. Xamarin Anroid App访问网站失败
  2. 使用NGUINGUI的相关介绍
  3. BeagleBone Black项目实训手册(大学霸内部资料)
  4. mysql之对视图的操作
  5. BZOJ3775 : 点和直线
  6. RowDataBound事件
  7. 1.Java为什么能跨平台运行?请简述原理。
  8. OS | 读写锁【摘】
  9. Android 通用流行框架大全
  10. ProtocalBuffers学习记录