• Android前端人员与后台开发的撕逼(一)


      首先表明一下身份,本人是Android前端开发人员,本篇只做合理性探讨,不进行人身攻击; 

    其次希望各位大神进行点评!点评!点评!  

    我们讨论一下接口的两种返回方式,直接举例说明一下,假设书籍信息表有30个字段,现在有各种排行榜和列表都需要显示书籍基本信息,但显示的属性一般会有5-8个左右,各个排行榜显示的字段内容有可能不一样,每个版本显示的属性也可能不一样,那么问题来了,是每次排行榜和列表都返回所有的30个字段还是每次按需返回相关字段呢?

    方案一:每次列表和排行榜都返回所有字段

    优点:接口稳定,不需要每次升级增加或修改字段

    缺点:字段冗余,消耗流量

    方案二:按需返回相关字段

    优点:减少冗余字段,数据不乱,结构清晰

    缺点:升级版本或需求改变的时候接口需要作对应调整

     

    我个人趋向于采用第二种方式,原因就是方案二的优点比较适合移动端开发规范,而针对于方案二的缺点,我建议服务器端建立按字段返回内容的框架,举例说明A排行榜需要BookId,BookName,BookScroe,另一个排行榜B需要返回BookId,BookName,BookDesc,那么后端实现逻辑可简写为:

    Public object getA_List() //获取排行榜A

    {

       Return getBookInfo(new String[]{BookId, BookName, BookScroe});

    }

     

    Public object getB_List() //获取排行榜B

    {

       Return getBookInfo(new String[]{BookId, BookName, BookScroe});

    }

     

    Public object getBookInfo (String[] m_Param) //统一获取书籍信息的方法

    {

       //实现逻辑

    }

    同理、同一个排行榜A升级版本只需做分支判断就好了; 

    另外这个getBookInfo(String[] m_Param)在服务器端定义完后,是否客户端根据每次变化,调用getA_List()方法的时候把需要的后台字段,,比如后台定义方法如下:

    Public object getA_List(String[] m_Param) //获取排行榜A

    {

       Return getBookInfo(m_Param);

    }

    那么后端接口就相对稳定,而前台也可以灵活地根据需要的字段来进行获取了?

    我个人意见呢依然是让服务器端来处理这类逻辑,理由:

    1、 我们需要做的客户端尽量是瘦客户端;

    2、 前台人员不需要关注后台数据表的结构设计,能够快速地进行效果和流畅度的开发,也就是说前端和后端应该是透明的;

    3、 考虑到安全性问题,因为如果前端传递参数的话后台数据库的结构表都暴露出来了。

     

    最后,还是希望各位大神不吝赐教!

     

  • 相关阅读:
    OpenCV+Python车牌字符分割和识别入门
    加载多卡训练的预训练模型Default process group has not been initialized, please make sure to call init_process_
    人脸识别数据集的采集
    显式转换和隐式转换
    Python经典机器学习的四大常用的第三方库
    kvm管理工具
    openstack+kvm还是k8s+docker ?
    Python Web开发常用的第三方库有哪些
    关于yum不能正常使用的解决方案
    升级centos正确姿势
  • 原文地址:https://www.cnblogs.com/Hua-Min/p/5424191.html
Copyright © 2020-2023  润新知