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,可以直接放个'*'
,代表所有地址
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
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
ssl证书和密钥生成参考链接:
https://blog.csdn.net/m0_37518406/article/details/79380534
这个有问题,我用浏览器设置信任的证书也不好用,会拒绝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:有问题请指正,感谢大家的阅读
原文地址:https://blog.csdn.net/qq_44063711/article/details/123281272
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_24656.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!