一、关于RESTful架构
REST这词是Roy Thomas Fielding在他2000年的博士论文中提出的。他利用REST定义了互联网软件的架构原则,即Representational State Transfer缩写,直译过来就是“表现层状态转化”,如果一个架构符合REST原则,就称它为RESTful架构。REST所指向的是在互联网中资源属性,其指明的是“Resources”的表现层,即概括成就是可以利用REST原则构建API能够找到独一无二的“资源实体”,如图片、音频、特定的数据等。简单概述RESTful架构有以下几个重点:
1.每一个URI代表一种资源;2.客户端和服务器之间,传递这种资源的某种表现层;3.客户端通过四个HTTP动词(GET、POST、PUT、DELETE)对服务器端资源进行操作,实现“表现层状态转化”。具体的可以看构建实现的例子。
二、关于Jersey、Maven
Jersey是JAX-RS(The Java API for RESTful Web Service)标准的参考实现,是Java领域中最纯正的REST服务开发框架。
Apache Maven是一款软件项目管理和理解工具。基于项目对象模型(POM)的概念,Maven可以从中央信息管理项目的构建,报告和文档。三、具体实践
1.依赖环境JDK、Maven、Tomcat
安装JDK和Maven时候需要注意的配置环境变量的问题,这其中需要注意的是下载的Maven和Tomcat都是需要时Binary 包,这样就可以直接解压后就可以直接运行无需编译:
1.1.mac环境下:
可以利用vim ~/.bash_profile来配置JDK和Maven的环境变量PATH,配置完成后执行source ~./bash_profile来让配置文件生效
#JDKJAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.8.0_162.jdk/Contents/HomePATH=$JAVA_HOME/bin:$PATH:.CLASSPATH=$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar:.export JAVA_HOMEexport PATHexport CLASSPATH#Mavenexport M2_HOME=/Users/bing/apache-maven-3.5.22export PATH=$PATH:$M2_HOME/bin
验证是否配置好,可以在terminal上面输入mvn -v命令看,系统是否识别如下图:
1.2.Windows环境下:可以通过高级系统设置来配置环境变量
2.利用mvn命令来创建webapp的例子(以mac环境下为例)
sudo mvn archetype:generate -DarchetypeArtifactId=jersey-quickstart-webapp \ -DarchetypeGroupId=org.glassfish.jersey.archetypes -DinteractiveMode=false \ -DgroupId=com.example -DartifactId=simple-service-webapp -Dpackage=com.example \ -DarchetypeVersion=2.26
cd simple-service-webappsudo mvn clean package
这样就已经把刚才构建基于maven所构建的Jersey RESTful Web Service的war就已经同mvn构建好了如下图
3.启动Tomcat来发布此Web Service项目
在Apache Tomcat下载Binary的包后,通过Terminal终端进入Tomcat的bin目录下
bash startup.sh
如此便是已经将web service部署到了Tomcat中了,并且已经发布了这样就可以通过URI来访问我们的项目资源,如在原来的项目中所需要留意的两个地方是,第一个是webapp文件夹下web.xml,如下图
Jersey Web Application org.glassfish.jersey.servlet.ServletContainer jersey.config.server.provider.packages com.example 1 Jersey Web Application /webapi/*
其中的<url-pattern>/webapi/*</url-pattern>
中webapi就是访问路径一个名字,
@Path("myresource")public class MyResource { /** * Method handling HTTP GET requests. The returned object will be sent * to the client as "text/plain" media type. * * @return String that will be returned as a text/plain response. */ @GET @Produces(MediaType.TEXT_PLAIN) public String getIt() { return "Got it!"; }}
所以上手的样例所要访问的URI是:
:8080/simple-service-webapp/webapi/myresource/
这样就可以开始项目具体业务的开发了。
后续会继续完善Windows和Linux版本的环境的搭建,以及基于Docker容器项目部署。