16年2月的一次代码重构,面对如此肮脏丑陋的代码我困在了座椅上整整一天的时间。

底层用java写的api接口,通过http去调用,在之上是用php写的业务逻辑层,重构的代码,正是php这一层。

 public function meetList(){
$timeBucket = array(
"all" => array("start"=>"","end"=>"",'type'=>1,'playStatuses'=>''),
"now" => array("start"=>date('Y-m-d'),"end"=>date('Y-m-d'),'type'=>1,'playStatuses'=>''),
"week" => array("start"=>date('Y-m-d', time() + 86400 * 1),"end"=>date('Y-m-d', strtotime("+7 day")),'type'=>2,'playStatuses'=>''),
"month" => array("start"=>date('Y-m-d', time() + 86400 * 1),"end"=>date('Y-m-d', strtotime("+30 day")),'type'=>2,'playStatuses'=>''),
"weekHistory" => array("start"=>date('Y-m-d', strtotime("-7 day")),"end"=>date('Y-m-d', time()),'type'=>4,'playStatuses'=>3),
"beforeWeek" => array("start" => date('Y-m-d', strtotime("2000-1-1")),"end" => date('Y-m-d', strtotime("-7 day")),'type'=>4,'playStatuses'=>3),
"day" => array("start" => date('Y-m-d', strtotime(I('get.day'))),"end" => date('Y-m-d', strtotime(I('get.day'))), 'type'=>1),
);
if(I('get.select') != "") {
$hot = array('click','join');
$postData = array(
'page'=> I('get.page', 1),
'limit'=> I('get.limit',20),
'uid' => I('get.uid'),
'meetClass'=> I('get.meetType')?I('get.meetType'):"",
'type' => in_array(I('get.select'), $hot) ? I('get.select') : $hot[1],
'timeType' => $timeBucket[I('get.timeBucket')]['type'],
'playStatuses'=> $timeBucket[I('get.timeBucket')]['playStatuses'],
'sdate' => $timeBucket[I('get.timeBucket')]['start'],
'edate' => $timeBucket[I('get.timeBucket')]['end']
);
$result = $this->getData('meet/hotMeetList',$postData);
} else {
$postData = array(
'uid'=> I('get.uid',''),
'meetClass'=> I('get.meetType')?I('get.meetType'):"",
'page'=> I('get.page', 1),
'limit'=> I('get.limit',20),
'type' => $timeBucket[I('get.timeBucket')]['type'],
'playStatuses'=> $timeBucket[I('get.timeBucket')]['playStatuses'],
'sdate' => $timeBucket[I('get.timeBucket')]['start'],
'edate' => $timeBucket[I('get.timeBucket')]['end']
); $result = $this->getData('meet/meetList', $postData);
}
if(!$result['success'] && !$result['data']['topics']['items']){
$this->ajaxReturn($result);
}
$items = $result['data']['topics']['items'];
$mids = i_array_column($items,'id');
$status = $this->getData('user/relatedMeetStatus', array('uid' => I('get.uid'), 'mids' => implode(',', $mids)));
$favoriteds = array_reduce($status['data']['meets'],function($w,$v){
$w[$v["mid"]]= $v;
return $w;
} );
foreach ($items as $k => $val) {
$value['mid'] = $val['meetBase']['mid'];
$value['playStatus'] = $val['meetBase']['playStatus'];
$value['priority'] = $val['meetBase']['meetPriority'];
$value['meetTitle'] = $val['meetBase']['meetTitle'];
$value['holdDay'] = date('Y-m-d', strtotime($val['meetBase']['startTime']));
$value['startTime'] = date('H:i', strtotime($val['meetBase']['startTime']));
$value['endTime'] = date('H:i', strtotime($val['meetBase']['endTime']));
$value['addr'] = $val['meetBase']['addr'];
$value['oid'] = $val['meetBase']['oid'];
$value['cnName'] = $val['orgBase']['cnName'];
$value['guestSpeaker'] = $val['meetBase']['guestSpeaker'];
$value['pstatus'] = $val['meetBase']['pstatus'];
$value['coverUrl'] = $val['meetBase']['coverUrl'];
$value['logo'] = $val['orgBase']['logo'];
$value['favorited'] = $favoriteds[$value['mid']]['favorited'];
$items[$k] = $value;
}
$result['data']['topics']['items'] = $items;
$this->ajaxReturn($result);
}

这些代码都做了什么。第一部分根据http发送过来的参数不同而做适应接口调用传递的参数。通过get.select[GET请求的select参数]值的判断而组装不同的数据调用不同的接口。再根据页面的需求调用user/relatedMeetStatus接口将数据组装到response中,最后还有一段数据的抽取与格式化。

整整70行代码,绝大部分是赋值语句,这样的代码看起来又臭又硬,编程的艺术在哪儿?

我想优化它,却无从下手!

它应该存在,就是一坨屎,与艺术无关。

这些代码就像是一个肮脏的动物进城之前清洗衣服而已,或许是一个快递员将一个货物送进城。不管它进城之后的加工有多么的艺术优雅,总之进城之前就是用马车压过马屎拉过进来的。这些就是马屎,碾过这些马屎才能进入优雅的大堂。同样,在response的时候也如下乡一样,快递员又用马车压过马屎拉下乡了,这是体力活,没有艺术,别谈优雅。臭,去臭吧。

或许,我们应该给它一个名字“HTTP处理层”,

它干什么呢:

表单数据验证

数据过滤

拼接

调整

字段重命名

格式化

这些工作,是与业务无关的,它的实现也没有什么艺术价值,完全可以单独隔离出来,称它为“HTTP处理层”。

注意,这一层一定与业务无关,它所做的是又臭又硬又脏体力活。

那么问题来了,我们怎么判断它是否与业务无关的呢:

业务层所提供的是需要保证业务完整性的,它就如你给乡下配送一个电视机一样,必须是完整的一台电视机,你不能讲显像管与机身分开,不是一个完整的业务。

对,这是http处理层的更多相关文章

  1. iOS总结_UI层自我复习总结

    UI层复习笔记 在main文件中,UIApplicationMain函数一共做了三件事 根据第三个参数创建了一个应用程序对象 默认写nil,即创建的是UIApplication类型的对象,此对象看成是 ...

  2. 终于等到你:CYQ.Data V5系列 (ORM数据层)最新版本开源了

    前言: 不要问我框架为什么从收费授权转到免费开源,人生没有那么多为什么,这些年我开源的东西并不少,虽然这个是最核心的,看淡了就也没什么了. 群里的网友:太平说: 记得一年前你开源另一个项目的时候我就说 ...

  3. UWP开发之ORM实践:如何使用Entity Framework Core做SQLite数据持久层?

    选择SQLite的理由 在做UWP开发的时候我们首选的本地数据库一般都是Sqlite,我以前也不知道为啥?后来仔细研究了一下也是有原因的: 1,微软做的UWP应用大部分也是用Sqlite.或者说是微软 ...

  4. java中Action层、Service层和Dao层的功能区分

    Action/Service/DAO简介: Action是管理业务(Service)调度和管理跳转的. Service是管理具体的功能的. Action只负责管理,而Service负责实施. DAO只 ...

  5. ABP领域层

    1.实体Entites 1.1 概念 实体是DDD(领域驱动设计)的核心概念之一. 实体是具有唯一标识的ID且存储在数据库总.实体通常被映射成数据库中的一个表. 在ABP中,实体继承自Entity类. ...

  6. JavaScript学习笔记(一)——延迟对象、跨域、模板引擎、弹出层、AJAX示例

    一.AJAX示例 AJAX全称为“Asynchronous JavaScript And XML”(异步JavaScript和XML) 是指一种创建交互式网页应用的开发技术.改善用户体验,实现无刷新效 ...

  7. jQuery遮罩层登录对话框

    用户登录是许多网站必备的功能.有一种方式就是不管在网站的哪个页面,点击登录按钮就会弹出一个遮罩层,显示用户登录的对话框.这用方式比较灵活方便.而现在扫描二维码登录的方式也是很常见,例如QQ.微信.百度 ...

  8. 使用CSS3的box-shadow实现双透明遮罩层对话框

    box-shadow介绍 在我之前的一篇文章<从天猫和支付宝身上学习opcity与rgba>中,介绍了实现双透明遮罩层效果的两种方法,分别是opacity和rgba.他们需要分别依赖于不同 ...

  9. ABP(现代ASP.NET样板开发框架)系列之10、ABP领域层——实体

    点这里进入ABP系列文章总目录 基于DDD的现代ASP.NET开发框架--ABP系列之10.ABP领域层——实体 ABP是“ASP.NET Boilerplate Project (ASP.NET样板 ...

  10. ABP(现代ASP.NET样板开发框架)系列之11、ABP领域层——仓储(Repositories)

    点这里进入ABP系列文章总目录 基于DDD的现代ASP.NET开发框架--ABP系列之11.ABP领域层——仓储(Repositories) ABP是“ASP.NET Boilerplate Proj ...

随机推荐

  1. [公告][重要]Senparc.Weixin v4.9.0 & Senparc.Weixin.MP v14.3.104更新说明

    本次升级除了更新了发红包接口等接口之外,最重要的是重构了缓存模块. 如何升级? 之前的缓存是为Container设计的,原先的ContainerCacheStrategy继承自BaseCacheStr ...

  2. Python框架之Tornado(四)源码之褪去模板外衣的前戏

    执行字符串表示的函数,并为该函数提供全局变量 本篇的内容从题目中就可以看出来,就是为之后剖析tornado模板做准备,也是由于该知识点使用的巧妙,所有就单独用一篇来介绍了.废话不多说,直接上代码: # ...

  3. 高德地图-搜索服务-POI搜索

    高德地图-搜索服务-POI搜索 之前公司项目收货地址仿饿了么的收货地址,结果发现自己实现的关键字搜索和周边搜索,搜索到的poi列表跟饿了么的并不完全一样,后来考虑了下,应该是搜索的范围.类型之类的设置 ...

  4. easyui相关script的配置

    <!-- 1 jQuery的js包 --> <script type="text/javascript" src="jquery-easyui-1.4. ...

  5. atitit.闭包的概念与理解attilax总结v2 qb18.doc

    atitit.闭包的概念与理解attilax总结v2 qb18.doc 1.1. 闭包(Closure)是词法闭包(Lexical Closure)的简称,是引用了自由变量的函数.1 2. #---- ...

  6. 解读sencha touch移动框架的核心架构(一)

    sencha的前身就是Extjs了,sencha 框架是世界上第一个基于HTML5的Mobile App框架 那么何谓框架,传统软件工程对于库和框架的区分主要着眼于对应用运行流程的控制权,框架提供架构 ...

  7. 数据结构与算法JavaScript (一) 栈

    序 数据结构与算法JavaScript这本书算是讲解得比较浅显的,优点就是用javascript语言把常用的数据结构给描述了下,书中很多例子来源于常见的一些面试题目,算是与时俱进,业余看了下就顺便记录 ...

  8. Android之登录那点事

    随着互联网的高速发展,一个应用为了保护用户的隐私,通常会通过设置用户名+密码的验证方式保证用户隐私的相对安全,我知道一般网站的登录验证,通常会设置一个二维码,通过验证二维码,防止恶意软件通过机械程序, ...

  9. ASP.NET WebAPi之断点续传下载(中)

    前言 前情回顾:上一篇我们遗留了两个问题,一个是未完全实现断点续传,另外则是在响应时是返回StreamContent还是PushStreamContent呢?这一节我们重点来解决这两个问题,同时就在此 ...

  10. Hawk: 20分钟无编程抓取大众点评17万数据

    1. 主角出场:Hawk介绍 Hawk是沙漠之鹰开发的一款数据抓取和清洗工具,目前已经在Github开源.详细介绍可参考:http://www.cnblogs.com/buptzym/p/545419 ...