php怎么写bug,PHP后端很难返回规范的JSON数据吗?
PHP作为当下主流的脚本语言,因其简单高效的特点备受关注,基于PHP开发的项目也是很多的,可以说PHP是作为Web开发的首选开发语言。但是PHP本身是弱类型语言,所以在某些地方的支持度上也是存在一些问题的,比如对于JSON的处理就存在一定的差异化。
PHP弱类型可能会导致JSON返回时不够标准PHP它是弱类型的脚本语言,所以在输出方面所有类型默认会被当成String输出。可能有PHP开发者不太理解这句话,举例来说:如果通过PHP从数据库中查询数据,那返回的数据其实都被当成了String类型,即使字段类型是int、double这类的也会被当成String处理。
在这种情况下,不同的开发者写出来的JSON可能就存在差异,比如:
{"name":"张三","age":22}或
{"name":"张三","age":"22"}另外在PHP环境下输出对象类型的字段时,也会出现问题,有些时候下会将{}返回成[],比如:
{"name":"张三","info":{}}或
{"name":"张三","info":[]}上面例举的这2个例子危害性很大,特别是作为API输出时会让调用方崩溃。
PHP后端如何规范返回JSON?弱类型语言看似方便容错性高,其实更容易出现Bug,这也是一些安全系数要求高的项目并不会采用PHP这类弱类型语言去开发的原因。
那PHP在对JSON处理这块应该怎么做呢?我的建议就是定义好数据返回模板,然后进行数据填充生成JSON字符串再返回。
以上就是我的观点,对于这个问题大家是怎么看待的呢?欢迎在下方评论区交流 ~ 我是科技领域创作者,十年互联网从业经验,欢迎关注我了解更多科技知识!726正式发布?
个人感觉 还是PHP5.6好用,不知道是我个人怀旧还是怎么地,但是不可否认的是 PHP7确实比先前的版本的性能提高很多,
7版本里修改了好几项内容,Session就是其中之一
Session:
. Fixed bug #74892 (Url Rewriting (trans_sid) not working on urls that start
with "#"). (Andrew Nester)
怎样开发一款软件?
喜望软件基于十年的软件应用开发经验给大家详细讲一下我们的App标准化开发流程。
我们按工作的性质不同先把App开发分成三个阶段:售前、售中、售后,每个阶段包括了多个步骤,循序渐进,最终完成项目的开发。
一、售前
1.需求沟通
在意向客户提出有项目需求时,我们的产品经理会跟售前顾问一起跟客户进行沟通。有些客户对于自己的需求通常只是一个大方面的想法,这个时候就需要我们专业的产品经理帮他整理出项目的具体需求和功能列表清单,并帮客户分析出没有考虑到的或能否实现的需求。
2.项目可行性分析
客户自身和产品经理都需要清晰了解该项目的功能特点、用户痛点、行业需求和为用户提供的服务内容等,每一点都要做出详细的调查分析,尤其是客户痛点这块。如果开发出来的App存留很多痛点,那么就算开发成功,也没多长时间的存活时间。因为任何一个App最终的成功都是建立在用户基础之上的。
(喜望某项目的解决方案)3.功能流程梳理
(1)整理架构
整理架构的过程就像是修房子打地基,产品经理会梳理产品整体功能架构,整理出核心内容,打造产品的地基,以确保客户以后可以在这个原有的基础上进行调整,更为方便、更具有扩展性。
(2)功能列表
接下来,产品经理会做出更详细的功能列表,添加每个模块的细节内容及具体功能,比如“注册”用哪种注册方式,短信验证码还是第三方注册等。这部分就像你在装修毛坯房时,首先要考虑加上门窗、水电改造等。
(3)梳理流程
产品经理会根据客户的需求梳理出产品的核心业务,会帮客户提前考虑到他们现有的流程是否可以在互联网上进行操作,例如一些传统行业转互联网的企业客户,产品经理会站在移动互联网的专业角度帮客户梳理并优化流程。
4.量身定制实施方案
当需求文档确认完毕之后,售前顾问会根据客户需求量身定制一套App开发方案和报价清单,包括项目组人员安排、时间节点安排和技术方案等,待客户确认完之后就可以开始正式签约合作了。
二、售中1.产品设计
(1)原型设计与评审
喜望产品经理根据需求文档设计出高保真原型图,包括功能的结构性布局、各分页面的设计、界面交互逻辑的设计等。高保真原型图将需求文档转换为更直观的软件demo版本,这样即可以确认更多的细节,保证项目研发的效果,也能避免沟通不畅或沟通不到位而引发的纠纷问题。
(喜望某项目的高保真原型图)(2)UI设计与评审
原型图设计确认好之后,UI设计师会根据产品的定位和原型图设计UI界面效果图了,相当于是在原型图的基础上加上颜色、确定产品整体风格、功能具象化处理、交互设计和排版布局等,使客户更直观的可以看到App的雏形,具有极高的还原度,能够为用户带来更高的体验度。一个完整的App需要一个吸引用户眼球的创意,这就需要产品经理和UI设计师在创意策划上有着独到的见解。
(3)需求详细讲解
产品经理会跟项目经理对接需求和原型图UI图,讲解客户的详细需求、功能板块、跳转页面等,项目经理需要细化需求,将这些需求和图片翻译成工程师们能更好理解的语言。接着,项目组会搭配着原型图UI图来召开技术会议,统一进行项目需求讲解。
(4)技术标准制定
项目经理在了解清楚整个项目的需求后提供易扩展、可持续迭代的技术框架方案,比如是原生开发还是混合开发、用Java还是PHP、还有第三方选型等。
2.敏捷开发
(1)迭代开发计划
在正式进入项目开发之前,项目组会对项目本身进行评估,对研发周期、提测时间、预发布时间点进行初步的判断。接着对项目功能进行分解,把项目需求划分成4-5个节点,比如1号-9号做第一个功能模块,10号-15号做第二个功能模块……项目组把迭代开发计划发给客户确认后,就开始按着这个计划做节点研发了。
(喜望某项目的开发节点计划表)(2)节点研发
按照需求分析整理出来的功能数据处理情况,项目组会建立合理的数据库表结构,优化数据算法,提升数据的处理效率,保证后期App使用过程中数据的安全性、准确性、稳定性和及时性。
一个完整的App项目一般包含以下几个模块:
①服务器端:编写接口协议文档,服务器环境架设(国内一般都是用阿里云服务器,国外一般用亚马逊),设计数据库和编写API接口,业务功能实现及接口封装、管理后台的开发。
②App端:根据UI设计图进行界面开发,UI开发完成后对接服务器接口,通过服务端接口获取数据,编写功能上的逻辑代码。
③Web管理端:根据前端的业务逻辑,后台会有相应的功能与之匹配,同样需要编写功能上的逻辑代码。
在项目研发阶段,项目经理进行技术攻关,流程助理同时跟踪进度,项目组也会每周向客户进行开发进度汇报,并协助客户申请软著。
(喜望某项目的总进度甘特图)(3)单元测试
以前的开发流程就是工程师从头写到尾,把App功能全部开发完成后再进行系统测试,这样就很容易出现以下几个问题:修改了一处bug却在另一处地方引发了新的bug、扩展新功能的同时导致旧代码出现bug等等,这个时候就需要引入单元测试。
单元测试简单来说就是工程师做一个节点研发,测试工程师就测试一个节点,这样就能够清晰的知道是否破坏了老的业务逻辑,容易排除掉一些非常低级的错误,大大减少回归出错的可能性和调试的时间,提高代码质量。
(喜望正在测试某项目)(4)系统测试
App功能开发完成之后,测试人员会对整个项目进行系统性测试。而完成项目测试调试最重要的环节是问题的管理,追踪各个bug的进度以及状态,包括指派给谁、优先级、修复状态等,以便有质量地完成问题的处理。
产品面向的平台多机型同步测试,包括:App内容测试、App性能测试、App功能测试、App视觉测试,对BUG调试修复。测试合格,确认没有bug后与客户进行沟通,开始验收,再由客户进行测试,提出修改意见。
3.上线交付
01.用户体验测试
喜望在2018年新设了一个“创新性人才岗位”——用户体验官,这是移动互联网行业首创的“从功能试错服务到运营实践服务”。
用户体验官的工作就是用户体验测试,从用户体验、产品、易用性、颜值、App设计还原度等多个维度进行体验性测试,并通过后台上传真实的前期种子数据,让整个App的内容很丰满,互动性强。用户体验测试是从项目本身的用户群体和运营逻辑来帮助客户打造好整个App的调性。
02.部署上线
在代码开发和测试完成后,就进入了后期上线的阶段。
(1)部署正式服务器:将数据库、后台系统部署到正式的服务器上面,并录入正式的上线数据到app系统后台。
(2)准备上架相关的资料:如软件著作权、应用说明、App界面截图和打包版等。
(3)发布App应用到市场:根据App端口选择发布iOS或Android应用市场。
①Android:涉及的应用市场很多,主流市场是腾讯应用宝、手机百度助手、360手机助手、91手机助手,不同的应用市场的受众属性和流量会有所不同,需要根据客户需求和项目实际情况来选择。一般来说,1-2个工作日就可以通过审核上线。
②iOS:发布到App Store,提交后一般最快都需要5个工作日左右才可以通过审核上架。因为App Store审核比较严格,比如是否符合最新的上架要求、是否涉及到虚拟货币、是否支持最新环境等很多问题都会决定审核能否通过。
但有可能会遇到这种情况:比如某App存在3个导致不通过的问题,App Store只要找到其中一个问题就不会通过,不会把3个问题都找出来告诉你为什么拒绝,所以如果经验不足,上架N次花费几个月都是很有可能的。
③发布小程序到微信公众号:需要把小程序发布提交给微信团队审核并上架,一般1-2个工作日就可以通过审核上线。
03.源码交付
APP开发测试上线后,要进行终验交付,即按照合同规定,将源码、说明文档、操作文档等所有项目的相关资料交付给客户。
包括但不限于:
1前后端项目的所有最新源代码(含注释)
2数据库设计文档
3API设计文档
4所有的开发者账号资料
5测试文档
6原型设计稿
7UI设计稿
8项目相关文档等资料
04.项目运营培训
在交付源码时,喜望的项目经理会给客户针对项目的所有功能操作进行培训,比如优惠券怎么发、司机怎么核审、怎么查看用户注册等。我们也会根据客户需求,让品牌设计师和新媒体运营官为客户设计上线海报和新媒体运营方案。
三、售后1.前期维护
一般的App开发完后都需要进行维护,即便是已经达到相对稳定的阶段,也可能随着手机系统的升级或长时间的使用等,出现一些小问题或隐藏得比较深的bug。
喜望会免费赠送客户三个月的维护期,一个项目正式上线运营了3个月左右的时候就已经清楚了整体的运营模式和部分功能欠缺,接下来想要继续运营app就需要迭代开发、优化功能模块。
在此期间,我们会解答客户的疑问、指导软件的使用和内容的上传等事项,以及修复程序Bug、突发情况发生后紧急维修等。
2.定制更新
在App投放到市场后,会得到用户以及市场本身的一些反馈,从而知道该如何修正或者调整运营策略,当目前系统的功能无法满足项目需求时,就需要规划新一版本功能的迭代问题了,也就是开发项目2.0。
喜望会帮助客户进行定制更新,也就是继续App开发前期“售前”所做的工作:需求沟通、可行性分析、功能流程梳理以及量身定制实施方案。
这个迭代方案一般根据以下2点进行制定:
①未完善的BUG
比如上线后的App在运营过程发现的一些BUG,或者逻辑错误的一些地方,如果我们想要修复这些逻辑错误问题和功能BUG,就必须进行App的迭代。
②App数据分析
数据是极其重要的衡量标准,通过分析App的投放资源、用户激活率、转化率、留存率和用户进入使用不同功能的占比、各个环节的流失,寻找对App体验影响较大的指标,分析自查功能设计上的优劣,以便进行功能上的版本迭代。
3.迭代开发
同样的,当项目进行迭代开发时,也会重新经历“售中”的全部过程,包含产品设计、敏捷开发和上线交付等所有的产品生命周期。
4.项目维护回访
当项目运营过一段时间(免费维护期结束)后,喜望会对客户进行回访,询问运营情况等。当然了,如果后续客户需要我们继续提供运维支持,我们也是很乐意的,因为在App运营的过程中需要与时俱进、维护更新,App才能长存。
5.新媒体运营
成功上线后的App可以通过企业的运营推广,发展用户数量,得以长久的运营。推广运营的方式有很多种,比如进行线下推广、投入广告、新媒体运营推广等。
贴心的喜望根据九年的从业经验以及目前市场情况,会推荐客户做成本相对较低的新媒体运营推广。
从上面的App开发流程来看,每一个项目研发都要经历以上3个阶段22环节,这其实是一条完整的流水线,做到这样往往能达到较高水准的项目质量。但是如何保证流程顺畅进行?如何使项目成员的工作效率最大化?这就十分考验开发公司的专业度和项目成员的规划能力了。
之前有讲到过,一款App开发的时间也会影响到App开发的价格,所以,了解一下App的标准开发流程还是很有必要的哟。
如果您想开发App软件,或者想了解更详细的开发流程、开发方案、报价等等相关内容,欢迎咨询成都喜望软件,有专业的售前顾问、产品经理为您详细解答App相关疑问。
开发一个app有多难?
互联网项目的开发有一套专业APP的设计和开发流程,关于这方面的文章也有很多,但大多数文章偏专业性。下文以新星咨询公司APP项目评估的流程为例子,站在技术委托方(客户)关注的角度,为大家剖析一下在开发过程当中,哪些是重要的里程碑节点,以及在APP项目开发过程需要双方交付和对接一些项目资料。
(全文约2000字,预计花费您5分钟阅读)
一、商务洽谈 & 合同阶段1. 功能需求思维导图:经过一些双方反馈调整后,产品经理跟甲方对接了解清楚整个项目需求,并绘制整个项目的功能思维导图策划方案(已经过技术和设计角度的可行性评估),最终产出清晰明确的功能需求说明。例如下图:
2. 需求报价方案:产品经理跟客户确定好功能需求后,项目经理拿到清晰完整的需求规划,进行整个项目的设计和项目开发测试评估,并产出项目的需求报价方案。如下图:
需求说明&报价单3. 技术开发合同:初步确认合作意向后,提供技术开发合同,如果双方对合同协议会异议,双方协商修改。
4. 开发进度文档:签订合同后,根据总开发周期,制定各开发阶段节点,并根据开发计划,推进后续的整个设计开发过程。例如下图:
技术节点示例二、设计阶段1. 原型设计稿:产品经理根据合同确认的功能需求,进行整个项目前端界面的原型设计。经过双方多次的沟通反馈调整,最终确认所有原型的设计。例如下图:
产品原型图例2. 原型交互流程图:在原型设计稿的基础上,加上每个页面的跳转交互流程标识,以便能够清晰了了解各个页面间的跳转和交互流程。如下图:
产品原型交互示意3. UI风格页:UI设计师会挑出几个主页面进行风格页的设计,一般会提供3-5个风格页的设计,确认整个UI的设计风格。
4. UI高保真设计稿:确认UI的风格设计后,便开始进行整个项目所有页面的高保真图设计,最终产出所有页面的高保真设计图,包括每一个页面的预览图,以及整个项目所有页面的预览大图。如图所示:
产品高保真原型示意图三、开发阶段1.注册相关账号:开发过程中,需要注册相关的开发者账号。包括部分但也不限于以下的开发者账号:苹果开发者账号,应用宝账号,微信公众号,支付账号,推送账号,阿里云账号,APP统计开发者账号,短信开发者账号,地图开发者账号等。
2.购买服务器,注册域名,备案:一般在上线前半到一个月,需要购买云服务器(如阿里云服务器),根据项目预估的运营情况(如未来一段时间的注册用户数,日活用户数,用户增加预估,用户的并发访问等情况),确认服务器的采购配置。如果项目需要分享到微信,或者有官方网站,则需要配备域名使用,需要提前购买好域名和服务器,并进行备案,备案一般需要7-10个工作日;
3.交付测试版本:完成项目的所有功能开发后(包括前后端功能的开发,一般在项目上线前的1-2周前交付,已经过内部初始几轮的测试,版本稳定),将打包发布测试的版本给甲方进行反馈测试。在经过1-3周的测试与反馈后,最终版本功能达到稳定流畅的上线状态。在此期间,双方都需要配置相关的人员进行项目的测试反馈问题。
四、项目上线:项目上线前,需要进行以下几步的操作:
1.准备上架相关的资料:如发布市场的打包版本,应用说明描述,截图,部署服务器和录入正式的数据等工作;
2.部署正式服务器:将数据库,后台系统部署到正式的服务器上面,并录入正式的上线数据到系统的后台;
3.发布APP应用到市场:国内的应用一般是发布到苹果的APPSTORE(iOS版本)和腾讯的应用宝(安卓版本)。APPSTORE提交后一般需要10个工作日左右可以通过应用的审核并上架,应用宝一般当天提交APP,当天就可以通过应用的审核并上线
4.发布H5或小程序到微信公众号:如果是微信H5的网站,只需要将网站部署并挂到小程序的菜单上面;如果是微信小程序,则需要把小程序发布提交给微信团队审核并上架;
五、运维阶段:1.免费运维阶段:项目上线后,项目便正式进入免费运维的阶段。一般免费运维期为3-12个月。在这个阶段中,技术开发方需要提供运维的服务,包括解答甲方的咨询服务,指导甲方的软件使用等事项,以及程序Bug的修复等内容。由于刚上线的版本前期bug会比较多,所以在这个阶段,协助甲方收集相关的问题进行修复并定时迭代上线新的版本;
2.交付项目资料:免费运维期到后,项目运行基本达到稳定状态,技术开发方需定期打包所有的项目资料交付给甲方,包括但不限于前后端项目的所有最新源代码,数据库设计文档,API设计文档,所有的开发者账号资料(数据库账号,服务器账号,苹果账号,微信开发者账号,安卓应用市场账号等等),测试文档,原型设计稿,UI设计稿,项目相关文档等资料。
3.付费运维阶段:后续如果甲方需要供运维支持,需要签订运维合同。一般运维费用为项目总开发成本的10% ~ 20%,根据项目的用户数量,功能量级及运维工作量进行费用的评估。
php网站项目运行速度慢?
排查 PHP 网站运行速度慢的原因 首先,使用浏览器的开发人员工具(Chrome)或Firefox的Firebug,确定,问题出在前端,还是后端。查看瀑布图,看看是卡在了服务器处理脚本上(典型特征是文档Waiting的时间特别长),还是前端(大量的图片、大量的JS、好多Flash)。90%网站性能问题是由前端造成的。 若确定是服务器端问题,看看PHP版本是不是过低了、使用XDebug的Profile结合Webgrind等,看看到底哪些函数执行的次数最多、单次时间最长、执行总时间最长,找到根源一击必杀!PHP的编译器不对PHP代码进行任何优化,所以某种意义上蛮考研PHPer的功力。