2024-11-06 02:46:32
本篇文章给大家谈谈django怎么写接口给别人调用,以及django怎么调用别人的接口对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
你这个问题应该是没有做过,你现在做的部分叫做服务器。
如果要别人通过ip来访问你的服务器,需要购买一个公网IP,这个是真正的IP地址,局域网那个是内部的。购买的话,途径有去供应商,比如电信公司网页去找,或者用阿里云服务器,自送一个IP。
在拥有公网IP的情况下,需要购买域名,即这个,购买后在相关网页上把公网ip和域名填写在一起,就绑定了,别人就能通过域名访问了。
这个很重要,在中国,域名是必须要去通管局注册登记的,不然会被封掉。。。
django-restful:与前端vue接口对接category与vue接口对接
首先是需要把所有的category的内容取出来
由于前端vue展示category是分级的
一级二级三级这样展示的
所以我们需要把三个内容都拿出来
但是首先需要取出第一级然后第一级镶嵌了第二级,然后第二级镶嵌第三季,就跟上面goods中显示外键的category的内容一样
我们还是需要写serializer
这样就是一级镶嵌二级二级镶嵌三级
但是这里有一个问题不要搞错了这三个类的位置不能弄错了
因为一级是调用二级所以二级一定是先写好了的
所以二级一定在一级上面同理三级要在二级上面
然后就是view
在过滤中加上category_type=1这样就可以直接显示第一大类然后第一大类中有第二小类这样更有层次感如果直接一下子全部取出来就不好分辨了
同时我们还要处理取出某个单一的信息
所以我们继承了mixins.RetrieveModelMixin这个类,这是一个显示详情的类
例如显示某个动物园的某个动物那样
/zoos/id
这样的url
同样这样写了我们就直接只配置category的url就够了
就不用考虑后面的id是否还需要配置一个url这些都不用考虑了,因为我们继承了viewset这个类
这些问题他都帮我们解决了
这样处理我们后端就能看见了
但是这样处理了前端对接时会发现无法显示
因为有一个跨域问题
这个问题前后端都可以独自解决这里学习的是后端,所以讲一下后端的做法
就是修改服务端
在github上搜索django-cors-headers就可以找到这个信息
同样里面介绍如何使用
安装
pipinstalldjango-cors-headers
然后settins中INSTALLED_APPS配置和settings中MIDDLEWARE配置
这里要注意MIDDLEWARE配置中
'corsheaders.middleware.CorsMiddleware',
'django.middleware.common.CommonMiddleware',
这两个必须放在
'django.middleware.csrf.CsrfViewMiddleware',
这个的前面不然会报错
同时还要配置
CORS_ORIGIN_ALLOW_ALL=True
允许跨域访问它默认是False
这样前端就可以正常显示了
为什么会产生跨域访问
因为vue中api配置的中我们调试数据不可能把所有的host都修改了有一些是线上数据我们调试的是本地的一部分数据所以要重新定一个localhost
修改部分host的链接
这样就导致了跨域本身使用的是一个线上host端口,但是数据中有一部分是请求的是本地host端口导致了跨域访问
DjangoRESTframework(一):接口与规范1)用api关键字标识接口url
2)接口数据安全性决定优先选择https协议
3)如果接口有多个版本存在,需要在url中标识体现
4)接口参数的数据源称之为资源,在url中一般采用资源复数形式,一个接口可以概括对该资源的多种操作方式
5)请求方式有多种,用一个url处理如何保证不混乱-通过请求方式标识操作资源方式
2)资源的状态码文字提示
4)不能直接返回的资源(子资源、图片、视频等资源),返回该资源的url链接
DjangoRESTframework框架之GET,POST,PUT,PATCH,DELETE等API请求接口设计
一、API接口功能需求:设计一些接口URL,让前端/客户请求这个URL去获取数据并显示,更改数据(增删改查),达到前后端分离的效果
二、设计逻辑:通过http协议请求方式GET、POST、PUT、PATCH、DELETE设计符合RESTful规范的api接口也就是URL
三、简易源码:
3.序列化serializers
#导入模型类和rest_framework序列化模块serializers
from.modelsimportArticle
fromrest_frameworkimportserializers
#定义序列化类,使用继承ModelSerializer方法
classArticleSerializer(serializers.ModelSerializer):
classMeta:
model=Article#指定序列化的模型类
fields='_all_'#选取序列化字段,此处可自行选取字段
4.视图函数views
fromdjango.httpimportHttpResponse
fromdjango.views.decorators.csrfimportcsrf_exempt
from.modelsimportArticle
from.serializersimportArticleSerializer
fromrest_framework.renderersimportJSONRenderer
fromrest_framework.parsersimportJSONParser
#调用csrf装饰器csrf_exempt模块,解决跨域访问问题
#JSONRenderer它将Python的dict转换为JSON返回给客户端
#JSONParser负责将请求接收的JSON数据转换为dict
#写法一
#在需要跨域的视图上调用装饰器@csrf_exempt
@csrf_exempt
defarticle_list(request):
ifrequest.method=='GET':
arts=Article.objects.all()#获取模型类数据
ser=ArticleSerializer(instance=arts,many=True)#序列化数据instance
#下一步用rest_framework方法里的JSONRenderer方法渲染数据
json_data=JSONRenderer().render(ser.data)
returnHttpResponse(json_data,content_type='application/json',status=200)
#写法二
classJSONResponse(HttpResponse):
def_init(self,data,**kwargs):
content=JSONRenderer().render(data)
kwargs['content_type']='application/json'
super(JSONResponse,self)._init(content,**kwargs)
#根据id进行增删改操作接口
@csrf_exempt
defarticle_detail(request,id):
try:
art=Article.objects.get(id=id)
exceptArticle.DoesNotExistase:
returnHttpResponse(status=404)
备注:
*写法二中定义JSONResponse类将返回的数据data与content_type返回类型做了封装
*API接口
GET/POST
GET/PUT/PATCH/DELETE
*Postman测试效果图
使用django开发一个比较简单的post接口先把前置条件说一下
1.首先搭建好django环境win+r打开命令提示符pipinstalldjango
3.然后创建一个自己的app
同样在命令提示符进入刚创建的工程所在路径输入pythonmanage.pystartappxxx(这个指你要创建的app名字),创新编辑器可以看到
4.正式开始开发一个post请求
首先设置好参数在seetings.py文件里如图修改
views.py
最后在templates文件夹下创建一个html文件简单地写一下前端
我这里直接贴自己写的login.html
code部分算是完成看一下效果
还可以进入fiddler查看验证,为了比较好查到我们先打开fiddler后输入用户名密码后fiddler上removeallsession
可以得到这么一条数据包
username,password的值也和我们输入的一致
到此完成一个简单的post请求开发
django怎么写接口给别人调用的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于django怎么调用别人的接口、django怎么写接口给别人调用的信息别忘了在本站进行查找喔。