前后端分离的流程设计
发布日期:2021-06-30 13:17:50 浏览次数:2 分类:技术文章

本文共 2488 字,大约阅读时间需要 8 分钟。

    之前自己分享过一版前后端分离的开发流程。

    这里需要提两个概念,一个是本地前端,另外一个是平台前端,本地前端是在内部迭代使用,界面可以简单一些,功能为主;平台前端是一个具有全局规划性的前端技术,简单来说,这是专业前端,会考虑用户体验度等等。

    我们要做一件事情,首先这件事情得能做成,然后把这件事情能做好。本地前端是保证这件事情能做成,而平台前端是保证这件事情能做好(至少看起来好)。为了保证表里合一,那么我们需要的就是核心的逻辑是同一套。640?wx_fmt=png

    所以提出这个概念之后,自己也在内部做了迭代和尝试,当然这个过程中也逐步的克服了一些技术恐惧的边界问题。其实回过头来看,事情似乎没想的那么痛苦。

    我使用的是Django的基础框架,其实对于我来说,对于ORM的部分功能还是很认可的。但是使用了RESTful服务之后,其实很多逻辑可以上移到API层来做。比较理想的状况就是Django的view层不用做逻辑处理,只是做页面的跳转的form data的跳转等。

    在这种情况下,后续如果要集成更加纯粹的前后端分离框架,其实就是水到渠成的事情了。

    比如对于防火墙的处理,iptables_show和iptables_add的操作,目前在view层已经没有实际的业务逻辑了。

def iptables_show(request):     return_dict = {}     src_ip = request.GET.get('src_ip', None) if src_ip == None: return return_response(request, 'iptables_manage/iptables_query.html', return_dict)     open_port = request.GET.get('open_port_list')     url = LOCAL_SERVER_URL+'/api/iptables_list/?src_ip='+src_ip+'&open_port_list='+open_port     result = api_access(url,'GET',request.user.id)     return_dict['result'] = result return return_response(request, 'iptables_manage/iptables_query.html', return_dict) def iptables_add(request):     return_dict = {} if request.method == "GET": return return_response(request, 'iptables_manage/iptables_manage.html', return_dict)     url = LOCAL_SERVER_URL+'/api/iptables_add'     data = request.POST     result = api_access(url,'POST',request.user.id,data) print(result)     return_dict['result'] = result return return_response(request, 'iptables_manage/iptables_manage.html', return_dict)

    这样一来,就可以对view层再做一层抽象,对前端的url可以做瘦身和精简,比如通过前端页面来配置API即可。

    整个逻辑的实现,其实下面的部分是难点,比如Django中的view层的url为:iptables_show,那么在API层使用RESTful服务的时候,需要再配置一个url为:api/iptables_show,然后两个url之间的关联关系从程序调用来说,是没有程序层面的依赖的,是一种绝对的隔离,核心仅在于API的url部分。我们完全是把服务以API的形式来调用,这样后续接入平台前端的时候,就很容易了。毕竟本地前端已经验证过功能了。

def getresponse_Token(url, token, api_method,data=None):     headers = {
"Authorization": "Token %s" % token} ss = requests.Session() if api_method == 'GET': r = ss.get(url, headers=headers, verify=False) elif api_method == 'POST': r = ss.post(url, headers=headers, data=data,verify=False) elif api_method =='PUT': r = ss.put(url, headers=headers, data=data,verify=False) res = json.loads(r.text) return res def api_access(url_str,api_method,user_id,data=None): if url_str == None: return ''    if url_str != LOCAL_SERVER_URL+'/api': api_method = api_method user_id = user_id token = Token.objects.filter(user_id=user_id) rs = getresponse_Token(url_str, token[0],api_method,data) return rs

转载地址:https://jeanron100.blog.csdn.net/article/details/102478867 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:SQL审核工具SQL Advisor简单体验
下一篇:MySQL中使用pt-osc的一些小结

发表评论

最新留言

哈哈,博客排版真的漂亮呢~
[***.90.31.176]2024年04月27日 11时59分58秒