本文介绍: 2 使用djangosslserver:在setting.py文件中找到INSTALLED_APPS,在里面添加一行变量,里面加的是自己服务器开放外部看的ip,一定得是自己服务器ip可以直接放个。(bash)查到地址端口号就是你自己设置开发端口了,一般本地是。可以指定,就是使用sslserver默认证书密钥。主要就是这种文件服务可以看情况建几个。–cert 指定使用证书。(2)非正常访问,直接设置忽略CA认证,还是可以用。–key 指定使用密钥。(1)正常使用证书访问,…

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&gt; 憨憨 </h1&gt;")
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 安装djangosslserver

pip install django-sslserver

2 使用djangosslserver:在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:有问题请指正,感谢大家的阅读

原文地址:https://blog.csdn.net/qq_44063711/article/details/123281272

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_24656.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注