概述
1.安装django
pip install django==1.10 # 双等号后面是版本
其他方法建议自己查
2.使用django创建项目
# 先创建个目录
mkdir django_item
cd django_item
# 然后就是创建项目
django-admin startproject test # test是项目名
3.创建运行的主要文件
3.1 创建view.py
主要就是这种文件做服务,可以看情况建几个
cd test
touch view.py
3.2.view.py代码如下
from django.http import HttpResponse
def hello(request):
return HttpResponse("<h1> 404 </h1>")
def world(request):
return HttpResponse("<h1> 憨憨 </h1>")
3.3 修改url.py文件
主要是用来绑定路径跟函数的关系
from django.conf.urls import url
from . import view
urlpatterns = [
url(r'test/hello', view.hello),
url(r'test/world', view.world),
]
3.4 使用命令运行
python manage.py runserver 0.0.0.0:8000
然后就可以用浏览器或者程序访问了
此处注意一个细节:就是只能本地访问(是说你只能把服务器运行在本地才能访问到)
自己去setting.py文件中找到并修改ALLOWED_HOSTS
变量,里面加的是自己服务器开放给外部看的ip,一定得是自己服务器的ip,可以直接放个'*'
,代表所有地址
1.浏览器:
直接输入以下网址就ok
http://ip:port/test/hello
http://ip:port/test/world
ip
是你自己的地址,port
端口号,可以通过ipconfig
(cmd)或者ifconfig
(bash)查到地址,端口号就是你自己设置开发端口了,一般本地是127.0.0.1:8000
2.程序访问
import requests
data = {}
r=requests.post(url=http://ip/test/hello ,data=json.dumps(data),timeout=30)
print(r.text)
3.5 创建html
我还没用过,看了下,不是很难,但是东西有点多,建议自己看链接:https://www.runoob.com/django/django-template.html
4.使用https
1 安装django-sslserver
pip install django-sslserver
2 使用django-sslserver:在setting.py文件中找到INSTALLED_APPS,在里面添加一行'sslserver',
3.使用命令运行
python manage.py runsslserver --cert ../key/server.crt --key ../key/server.key 0.0.0.0:8000
–cert 指定使用的证书
–key 指定使用的密钥
可以不指定,就是使用sslserver默认的证书和密钥
ssl证书和密钥生成参考链接:
https://blog.csdn.net/m0_37518406/article/details/79380534
4.访问运行的https服务器
1.浏览器访问
https://127.0,0.1:8000/test/world
这个有问题,我用浏览器设置信任的证书也不好用,会拒绝ssl,然后变红警告,但是也能访问,不过不是https,因为没ssl验证,只是看着https,实际上走的过程跟http差不多,
这个问题问了下别人,说是其实变红警告是用了ssl验证的,只不过是自己制作的证书不是CA认证机构认证的证书,所以会变红,所以实际上还是https加密访问
2.程序访问
(1)正常使用证书访问,还没找到答案,想问下大家,不知道是不是证书搞错了,但是服务器能运行,说明没问题,疑惑,有找到答案的朋友希望在评论区指下路
import requests
cert = ('./key/server.crt','./key/server.key')
r=requests.post(url=http://127.0,0.1:8000/test/hello ,data=json.dumps(data),timeout=30,cert=cert)
print(r.text)
使用以上程序会报错
requests.exceptions.SSLError: HTTPSConnectionPool(host=‘localhost’,port=8000): Max retries exceeded with url: /api/execmd_trans (Causedby SSLError(SSLError(1, u’[SSL:CERTIFICATE_VERIFY_FAILED] certificateverify failed (_ssl.c:727)'),))
(2)非正常访问,直接设置verify=false
,但是这种就是直接拒绝 ssl,没起到ssl的安全作用,不建议 忽略CA认证,还是可以用
import requests
cert = ('./key/server.crt','./key/server.key')
r=requests.post(url=http://127.0,0.1:8000/test/hello ,data=json.dumps(data),timeout=30,verify=false)
print(r.text)
ps1:这个是先记录下,遗留问题后面再加修改
ps2:有问题请指正,感谢大家的阅读
最后
以上就是朴实老虎为你收集整理的使用Django-sslserver搭建https服务器和访问的全部内容,希望文章能够帮你解决使用Django-sslserver搭建https服务器和访问所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复