网站后端使用java还是php多_服务器后端语言选择(PHP篇)

a202c68032ce85ee5fde925e3cecfd7e.png

背景图片 来自 Markus Spiske on Unsplash

ProjectX是现在我在做的一个项目的代号,我计划在整个项目的过程中做更多的尝试,并且尽可能的将过程记录下来。如果感兴趣可以关注我,非常欢迎给我或是ProjectX提提你的建议。

这次ProjectX在选择后端开发语言的时候,我不会考虑我自己的熟悉程度和之前的积累,希望可以比较客观的选择一个适合的后端语言,我也可以通过这个过程了解更多后端语言。目前计划尝试的后端语言有:PHP、JAVA、Node.js、Go、Rust、Ruby、Python。没有案例的分享都是耍流氓,我用这几个语言统一做一个简单的数据查询返回的API接口,来从服务器支持、开发环境搭建、RESTful路径设置、数据库连接、语言结构和文档社区丰富度六个方面来聊聊我自己的感受。

语言简介

PHP的全称是PHP:Hypertext Preprocesser (一个程序员的黑色幽默),最初Personal Home Page的简称,算是目前最流行的网站开发语言,从PHP的名称就能看出来,PHP最初就是为了开发网站而设计的编程语言。据统计目前有80%的网站是有PHP开发的,尤其著名的Wordpress就是基于PHP开发的。PHP对于我来说也是最熟悉的后端开发语言,已经用PHP开发了大概15年了,从以前开发网站到后来App的后端接口再到小程序的后端接口基本都是使用PHP。也就是因此,我的第一篇打算从PHP开始分享,毕竟比较熟悉不容易翻车。

服务器支持

既然是最流行的服务器端编程语言,服务器的支持绝对是最佳的,PHP通过Apache服务器可以安装在所有服务器操作系统上,包括Linux、macOS、Windows和Unix系统,就算使用其他Web服务器软件,如Nginx、Lighthttp、LiteSpeed等等也都支持,虽然可能没有Apache自带那么方便。现在云服务器的服务供应商基本上都支持携带Linux+Apache+MySQL+PHP的镜像安装。基本可以做到了开箱即用,而且对于绝大多数网络应用来说基本不需要做什么配置,直接将在本地开发环境中的代码上传到相应的文件夹就可以使用了。所以服务器支持基本上可以算是满分了,而且购买了云服务器之后基本不需要配置就可以开始部署代码,服务器配置也很快,在几个大的云服务商基本上确定了合适的服务器运算配置后,只要15分钟就能让一台LAMP服务器上线。

dedc956c64b04ee5dacdd5dfda1cebaf.png

LAMP构架的服务器

IDE vs. Editor

PHP作为解释性语言,可以不用依赖IDE,不过现在PHP的框架还是非常成熟可以提高不少开发效率,IDE的好处是能直接通过新建项目来生成这些框架的脚手架,比直接在命令行内生成要直观不少,为此我尝试了一下JetBrain的PhpStorm。虽然PhpStorm已经改成了订阅制的收费方式,不过还是小贵的。我先安装体验一下,再看看是不是值得购买。

964bff6899248cb61909fb3c9d894c87.png

一年一千多,还是有点小贵的

整个安装过程还是比较快速的,直接下载后拖拽入应用程序文件夹即可。然后打开PhpStorm先做了简单的配置和插件安装,可以看到PhpStorm对于主流的一些PHP框架都是有不同程度的支持的。这样新建项目的时候就可以直接选择需要的框架来搭建脚手架程序,非常方便,对于刚刚涉猎PHP的框架还是比较不错的,例如Symfony就可以直接建立带有Demo的项目,这样就可以边学边用。

093384c8102add4eb23429aefa6a3fb0.png

PhpStorm直接生成Symfony项目

不过个人比较不喜欢使用框架,而且这次ProjectX对于性能优化的要求并不是特别高,所以就不准备使用框架了,毕竟从无到有的开发还是蛮有成就感的。最终还是决定使用VS Code来做开发,结合一些VS Code的语言格式化和高亮等插件,VS Code基本能满足整体的开发需要。因为过程中可能会尝试一些新的技术,会通过学习一些已有第三方库来深度学习,所以还会通过Composer来安装一些PHP依赖库。

基本上PHP还是选择了Editor,开发配置会更直接一些,结合一些插件基本上就能着手开发了。

RESTful VS GraphQL

因为ProjectX计划是跨平台的前端,所以后端会通过API的方式来实现服务,之前一直使用的是类似RESTful的API设计,毕竟对于比较复杂的后端接口来说RESTful还是有一些局限的,而且往往没有足够时间来设计完整的RESTful API。后来出现了GraphQL,这次会多花点时间研究一下,GraphQL更像一个前端向后端传输的查询语句,可拓展性更高一些,这次在PHP中就试试能否使用GraphQL的接口规范。

在PHP中配置RESTful规范的API,主要是对路径的重写来实现相应的RESTful EndPoint可以直接重新定向到相应的PHP文件。达到路径重写需要通过加载rewrite模块就可以让Apache服务器支持路径改写,支持类似下面这样的路径来调用一个herb的资源对象。

http://localhost/herb/{id}

开启rewrite的方式是在httpd.conf文件中找到mod rewrite这行代码将注释标识符#去掉

#LoadModule rewrite_module lib/httpd/modules/mod_rewrite.so

再将服务器根文件夹中AllowOverride 从默认的None改成All,

DocumentRoot "ServeRoot"    Options Indexes FollowSymLinks    #    # AllowOverride controls what directives may be placed in .htaccess files.    # It can be "All", "None", or any combination of the keywords:    #   AllowOverride FileInfo AuthConfig Limit    #    AllowOverride All    Require all granted

在重启动服务器就完成了Apache的配置,接下来就是在项目的目录下通过建立 .htaccess文件来开启重写引擎和建立重写规则。通过正则表达式来匹配请求路径中的信息,然后再匹配到相应PHP文件以及PHP的传入参数。 如下是一个简单的重写规则:

RewriteRule "^api/herb/(.+)" "/api/herb.php?uid=$1"

完成重写规则之后,就可以在相应的PHP文件中编写业务逻辑了,例如在herb.php中根据不同的HTTP提交的请求方法来返回相应的JSON格式数据。例如一下通过Postman来测试的接口。

49bd4409572eb2008ff08edc7a6511f9.png

RESTful接口的返回测试

对于PHP来说建立一个RESTful规范格式的API,还是相对简单的,不过主要会在接口设计上花比较多时间,尤其对于比较复杂的业务场景,完全按照RESTful规范设计会很困难,尤其是在需要传路多个参数的时候。

GraphQL的出现实际上就是弥补RESTful的一些设计缺陷。不过因为之前一直没有花时间学习GraphQL,乘这次的机会深入了解一下。GraphQL基本上是一套前端发送查询语句到后端的规范,可以通过添加多个输入参数和指定返回数据的参数的方式,将数据传输变得更可控,而且还添加了数据类型的控制。

在PHP中使用GraphQL可以通过已有的第三方库,例如graphql-php、Railt、GraphQLite、Siler以及一些框架下的库,都是不错的选择,因为graphql-php应该算是PHP下对GraphQL实现的第一个库,所以是通过Composer安装了一下,尝试了一些GraphQL的机制,的确比RESTful灵活很多。如下在Postman中测试的接口,可以通过控制查询语句来控制返回的数据结构。

0383030c897cb1fd59579cd86e22c33c.png

GraphQL接口的返回测试

不过graphql-php的文档不是很完善,只提供了一些简单的操作方式,估计最终如果选择使用PHP来实现GraphQL的话,估计会自己写一个GraphQL的处理库或者找到一个完善一点的库。

e440b5446a5ae4edd5a1b9db15f1727d.png

对于PHP来说,无论是对RESTful还是对GraphQL的支持都中规中矩,都有第三方库支持,就算自己来做库也都不算太困难。

数据库连接

这个点PHP已经非常成熟了,原生的库基本就能解决所有问题,为了更适合ProjectX的和个人的习惯还是会做一定的封装,现在已有的开源框架对于这方面的支持也算是不错的,可以直接使用现有框架,当然自己写一个基础的库也可以让自己更熟悉PHP对于数据连接上的一些机制和支持性。

语言结构

PHP目前已经发展到了第7版,无论是面向对象的开发方式还是函数的开发方式都支持,而且PHP对于Class的支持还是中规中矩的,对于封装一些业务逻辑来说还是不错的,只是PHP作为一个弱类型的编程语言,对于变量类型的控制会比较弱一点,不过只要养成一定的开发习惯还是能规避一些这方面的问题的。

文档社区

作为最流行的网络应用开发语言,文档支持和社区支持非常成熟,可以在Github上找到任何类型的库解决绝大多数开发中的问题,类似CSDN、Stackoverflow这类网站上解答关于PHP的问题也非常多,PHP官方文档也支持中文,基础问题也直接能在php.net上解决。

总结

作为最流行的网络应用开发语言,PHP各方面都非常完善,是可以直接拿起用的后端开发语言。不过因为自己对于PHP太熟悉了,绝对挑战少了一些,所以这次基本上不会使用PHP作为后端开发语言,除非尝试下来其他语言都不适合后端开发,不过这个概率应该不大。


希望你喜欢这次的分享,如果喜欢的话,可以点赞让我知道一下!如有不同想法或是对之后内容的建议,可以在评论区讨论一下。

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 中间件和后端语言是两个不同的概念,它们之间没有包含或被包含的关系。 中间件是指应用程序和操作系统之间的软件层,它可以提供各种服务,例如消息传递、数据库连接、身份验证、缓存等。中间件通常是独立于后端语言的,可以使用任何编程语言编写。 后端语言是指用于编写服务器端应用程序的编程语言,例如Java、Python、PHP、Ruby等。这些语言可以使用中间件来提供各种服务。 因此,中间件和后端语言是相互独立的,它们可以混合使用,也可以分别选择不同的中间件和后端语言来构建应用程序。 ### 回答2: 中间件和后端语言之间存在一种包含关系。 首先,中间件是一种位于客户端和后端语言之间的软件,它提供了一系列的功能和服务。中间件可以用来处理和转换请求和响应数据,对数据进行验证和安全性检查,以及进行请求的路由、负载均衡等。中间件的目的是简化后端语言的开发,提高系统的性能和可扩展性。 后端语言是指用来开发和实现服务器端应用逻辑的编程语言后端语言可以是各种编程语言,如Java、Python、PHP等。它们提供了一系列的库、框架和工具,用于处理客户端请求、处理业务逻辑、访问数据库等。 中间件和后端语言之间的关系是相互包含的。中间件可以被视为后端语言的一部分,因为中间件一般是在后端语言的基础上进行开发和使用的。后端语言提供了一种接口和机制,使得中间件可以被集成和调用。同时,中间件也可以包含后端语言的一部分功能,例如,某些中间件可能提供了对特定后端语言的支持和适配。 综上所述,中间件和后端语言之间存在一种相互包含的关系。它们相互依赖和协作,共同完成服务器端应用的开发和运行。 ### 回答3: 中间件和后端语言之间存在一种包含关系。 中间件是指在应用程序和操作系统之间的软件层,用于协调和处理不同系统之间的通信和数据传输。它可以提供各种功能,如安全性、身份验证、缓存、日志记录等,以增强后端语言的功能和性能。 后端语言则是指开发网站、应用程序等服务器端的编程语言,如Java、Python、PHP等。后端语言负责处理用户请求,执行业务逻辑,并与数据库进行交互等。 中间件和后端语言之间的关系是,中间件可以被后端语言调用和使用后端语言可以通过引入适当的中间件来增强自身的功能。例如,一个使用Java作为后端语言的应用程序可以使用Tomcat作为中间件来处理HTTP请求和响应,提供Servlet容器的功能。 此外,中间件还可以作为后端语言的一部分来使用。一些后端语言提供了自己的中间件,用于处理特定的功能或提供特定的服务。例如,Node.js作为后端语言,提供了Express.js作为其中间件,用于处理路由、请求、响应等HTTP相关的功能。 因此,中间件和后端语言之间是存在一种包含关系的。中间件可以增强后端语言的功能,同时后端语言也可以使用中间件来处理特定的功能或提供特定的服务。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值