Servlet编程第一步之从零构建Hello World应用详细步骤+图解
作者:VaporGas
前言
什么是Servlet?
- Servlet 是一个 Java程序,是在服务器上运行以处理客户端请求并做出响应的程序
什么是maven?
简而言之,maven是通过一小段描述管理和构建java项目的工具(通过pom.xml),我们通过maven项目可以快速导入项目需要的jar包,避免了手动导入jar包带来的不容易管理和依赖冲突问题。这里不详细赘述maven的使用
第一个Serlvet程序
- 手动编写一个Servlet主要需要以下几步:
- 创建一个servlet类,此类继承自HttpServlet
- 重写doGet和doPost方法中的一个
- 配置Servlet
第一步:创建一个maven项目
提前需要在idea中配置maven的相关配置
第二步:创建java目录,导入Servlet依赖jar包
此时maven缺少存放源码的java目录(参考maven教程),
右键main->单击NEW->单击Directory-->创建java目录
在pom.xml中配置Servlet依赖
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>org.example</groupId> <artifactId>maven_9_12</artifactId> <packaging>war</packaging> <version>1.0-SNAPSHOT</version> <name>maven_9_12 Maven Webapp</name> <url>http://maven.apache.org</url> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>3.8.1</version> <scope>test</scope> </dependency> <!--Servlet3.1--> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>3.1.0</version> <scope>provided</scope> </dependency> </dependencies> <build> <finalName>maven_9_12</finalName> </build> </project>
第三步:创建一个servlet类,此类继承自HttpServlet
重写doGet和doPost方法中的一个
import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.IOException; import java.io.PrintWriter; public class ServletTest extends HttpServlet { @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //设置响应类型和响应字符集,防止中文乱码 response.setContentType("text/html;charset=UTF-8"); //获取响应输出流 PrintWriter out = response.getWriter(); //在页面打印HTML标签(会解析成对应的效果) out.println("<html>"); out.println("<head><title>Servlet</title></head>"); out.println("<body>"); out.println("你好,欢迎来到Servlet世界"); out.println("</body>"); out.println("</html>"); //使用完毕,关闭流资源 out.close(); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doGet(req,resp); //目的是为了保证前端传入的get和post请求都能接收处理 } }
第四步:配置Servlet
- 在web.xml文件中配置Servlet
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd" > <web-app> <display-name>Archetype Created Web Application</display-name> <servlet> <servlet-name>httpServletTest</servlet-name> <servlet-class>ServletTest</servlet-class> </servlet> <servlet-mapping> <servlet-name>httpServletTest</servlet-name> <url-pattern>/demo1</url-pattern> </servlet-mapping> </web-app>
第五步:配置maven的服务器插件支持
一个web项目想要运行是需要服务器支持的,我们直接下载一个tomcat服务器进行配置,是比较繁琐的,可以通过maven插件 配置一个“虚拟的服务器”,供我们开发使用
在pom.xml文件中将build标签中的内容替换成下面的内容
<build> <finalName>web</finalName> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.1</version> <configuration> <source>1.7</source> <target>1.7</target> <encoding>UTF-8</encoding> </configuration> </plugin> <plugin> <groupId>org.eclipse.jetty</groupId> <artifactId>jetty-maven-plugin</artifactId> <version>9.3.14.v20161028</version> </plugin> <plugin> <groupId>org.apache.tomcat.maven</groupId> <artifactId>tomcat7-maven-plugin</artifactId> <version>2.1</version> <configuration> <port>8080</port> <path>/</path> <uriEncoding>UTF-8</uriEncoding> <server>tomcat7</server> </configuration> </plugin> </plugins> </build>
第六步:配置以服务器的形式启动
点击右上角的锤子旁边的小括号,选择Edit Configurations
点击左上角的+号,找到maven
将Run中改为jetty:run 或 tomcat7:run (具体看你在上面配置了哪些服务器)
两种服务器,jetty更加轻量级,推荐使用,当然tomcat也有自己的优点,这里不赘述
第七步:点击启动
点击启动,在浏览器中输入localhost:8080查看效果
此时会跳转到webapp中的默认首页index.jsp
第八步:访问Servlet
我们在web.xml中声明了访问Servlet的URL为demo1,所以可以如下访问
- 启动服务器(tomcat或jetty)
- 在浏览器中输入
总结
综上所述,一个简单的基于web.xml配置文件的JavaWeb的Servlet程序就完成了,我们可以创建多个页面,然后在web.xml中添加对应的Servlet和Servlet映射即可。
到此这篇关于Servlet从零构建Hello World应用详细步骤+图解的文章就介绍到这了,更多相关Servlet构建Hello World应用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!