Servlet還有學習的必要嗎?(手工搭建Servlet)


前言

  在初學Java web的時候,就曾聽到過這樣一種說法:
  java Web的演變過程大概可以分為4個階段:
    1. jsp + Servlet + jdbc
    2. spring + struts2+ hibernate(ssh)
    3. spring + SpringMVC + mybatis(ssm)
    4. 微服務階段。
  所以學習 Java web,可以從第3個階段開始學習,不用再去關注Servlet, 那么Servlet是否還有學習的必要呢?
答案是 有,並且非常重要。俗話說萬變不離其宗,這個宗指的就是技術的底層,你會發現技術的底層其實都是相通的,只要把握了這個宗,我們就能在技術的浪潮來臨時,把握機會,而不是去追逐一個又一個的泡沫。
  我記得初學java的時候,還是大三上,教我們java的老師是我們學院的副院長。他讓我們用記事本去編寫程序,用命令行去執行程序,而隔壁班用的卻是eclipse。當初非常羡慕隔壁班,能用上“高大上”的開發環境,不用去改一個又一個的編譯錯誤。現在想起來,卻非常感謝那段經歷,它讓我對Java程序的執行過程有了更直觀的認識,對java這門編程語言本身有了更深刻的認識。
而現在作為一個Java程序員,我們已經習慣了使用IDE和Web框架進行開發,IDE幫助我們做了編譯、打包的工作。Spring框架則幫助我們實現了Servlet接口,並把Servlet容器注冊到了Web容器中。這樣我們就可以專注於實現業務邏輯,但是同時,卻缺少了接觸底層的機會。
  如果程序一直都處於正常運行的狀態,不了解底層其實並沒有什么問題,但是如果程序一旦出現了預期之外的異常,那么如果我們不懂底層,就沒有辦法准確的定位問題。
所以今天要和大家分享的是Servlet的學習:

手工搭建一個Servlet

下載Tomcat

  首先我們需要下載Tomcat : https://tomcat.apache.org/download-90.cgi
  Tomcat的目錄如下: (Mac系統、Tomcat 8.5.38)
 
  • /bin:存放在windows(.bat)和Linux(.sh)環境下運行的腳本文件。
  • /conf: 存放配置的文件,其中最重要的是server.xml(配置Servlet)
  • /lib:存放Tomcat以及所有Web應用都可以訪問的jar文件
  • /logs:存放Tomcat執行時產生的日志文件
  • /work:存放JSP編譯后的產生class文件
  • /webapps:Tomcat的Web應用目錄

編寫Servlet程序

  我們可以通過繼承 GenericServlet抽象類或者 HttpServlet抽象類來實現我們自己的Servlet。HttpServlet是在GenericServlet的基礎上,進一步封裝了Http的特性,相對GenericServlet而言使用簡單,我們只需要重寫doGet和doPost方法即可。所以這里我們使用HttpServlet。(這里我們是使用記事本編寫的,如果你是使用ide,請引入javax.servlet包,因為這個包不在jdk的標准開發包中,方法可以參考: https://blog.csdn.net/q343509740/article/details/79515911)
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;

/**
 * 自定義Servlet.
 * 
 * @author jialin.li
 * @date 2019-12-15 20:46
 */public class MyServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        System.out.println("開始處理get請求");
        PrintWriter writer = resp.getWriter();
        resp.setContentType("text/html;charset=utf-8");
        writer.println("<h1>hello Servlet</h1>");
    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        System.out.println("開始處理post請求");
        PrintWriter writer = resp.getWriter();
        resp.setContentType("text/html;charset=utf-8");
        writer.println("<h1>hello Servlet</h1>");
    }
}

 

編譯程序

  這里需要我們將Tomcat lib中的Servlet-api.jar拷貝到當前目錄下。因為我們編寫的MyServlet繼承了HttpServlet抽象類,而這個類屬於該jar包,調用下面的命令編譯代碼:
javac -cp ./servlet-api.jar MyServlet.java
  可以看出,我們編譯成功,生成了一個class文件。
  接着我們需要創建一個Web應用的web文檔結構,把它放到Webapps中。結構如下:
MyWebApp/WEB-INF/web.xml
MyWebApp/WEB-INF/classes/MyServlet.class
  我們將在web.xml中配置我們的Servlet,web.xml的內容如下:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0"
metadata-complete="true">
<description> Servlet Example. </description>
<display-name> MyServlet Example </display-name>
<request-character-encoding>UTF-8</request-character-encoding>
<servlet>
<servlet-name>myServlet</servlet-name>
<servlet-class>MyServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>myServlet</servlet-name>
<url-pattern>/myservlet</url-pattern>
</servlet-mapping>
</web-app>
  這里要保證servlet和servlet-mapping中的servlet-name一致。這樣才能完成從url到servlet的映射。

啟動Tomcat

  接着我們啟動tomcat,找到tomcat的bin目錄,然后執行start.sh腳本(如果是windows系統,請使用.bat的腳本):
sh startup.sh
  tomcat的默認端口是8080,我們可以訪問一下myservlet,觀察結果: http://127.0.0.1:8080/MyWebApp/myservlet
hello Servlet
  MyWebApp是我們的應用名,即在webapps的文件夾,myservlet是我們配置在web.xml里的Servlet路徑。
(如果啟動tomcat出現異常,請移步 https://www.cnblogs.com/nedulee/p/12063786.html,里面有具體的解決辦法)

讀取日志

  讀tomcat的日志,也是后端開發工程師必不可缺的一項技能。它可以幫助我們快速的定位問題。tomcat中的日志分為兩類,一類是運行日志,記錄着系統運行過程中的信息,比如異常錯誤  等。一類是訪問日志,記錄着訪問的時間、IP地址、訪問路徑等相關信息。

catalina.***.log

  主要記錄着Tomcat啟動過程中的信息,這個文件可以看到JVM參數以及操作系統等日志信息。

catalina.out

  catalina.out是Tomcat的標准輸出和錯誤輸出,在這個日志里我們可以看到MyServlet.java程序輸出的信息。

localhost.**.log

  主要記錄Web應用在初始化過程中,遇到的未處理的異常。

manager.***.log/host-manager.***.log

  存放Tomcat自帶的Manager項目的日志信息
  除了使用xml的形式配置,servlet3.0又引入了注解開發的方式,大大簡化了開發流程,我們先修改代碼,給Servlet類加上@WebServlet注解:
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.annotation.WebServlet;
import java.io.IOException;
import java.io.PrintWriter;

/**
 * 自定義Servlet.
 *
 * @author jialin.li
 * @date 2019-12-15 20:46
 */
@WebServlet("/myAnnotationServlet")
public class MyServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        System.out.println("開始處理get請求");
        PrintWriter writer = resp.getWriter();
        resp.setContentType("text/html;charset=utf-8");
        writer.println("<h1>hello Servlet</h1>");
    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        System.out.println("開始處理post請求");
        PrintWriter writer = resp.getWriter();
        resp.setContentType("text/html;charset=utf-8");
        writer.println("<h1>hello Servlet</h1>");
    }
} 
  這個注解有兩層含義: 這個Java類是一個Servlet;這個Servlet對應的url路徑是myAnnotationServlet
  然后我們需要重新編譯文件,並刪除原來的web.xml,重新啟動tomcat,驗證結果:
hello Servlet
  可以看出,使用注解和使用配置文件的效果是一樣的。
 
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM