今天介紹的專題是servlet和jsp,屬於web開發中的基礎,先來實際操作一下servlet,創建你的第一個web小項目。 1、新建一個maven項目。 滑鼠右鍵單擊eclipse左邊項目欄的空白區,選擇第一個new,在出現的下拉中選擇other,在新彈出的框中選擇maven,點開maven選擇m ...
今天介紹的專題是servlet和jsp,屬於web開發中的基礎,先來實際操作一下servlet,創建你的第一個web小項目。
1、新建一個maven項目。
滑鼠右鍵單擊eclipse左邊項目欄的空白區,選擇第一個new,在出現的下拉中選擇other,在新彈出的框中選擇maven,點開maven選擇maven project,點擊next。在新彈出的框中勾選上面的第一個按鈕Create a simple project (skip archetype selection),再點擊next。在新彈出的框中,第一行Group Id,這裡可以是項目的部分地址或者公司的部分網址,如com.baidu等,只是要反寫;第二行Artifact Id,這是項目名,比如我們現在要建的項目,可以叫servlet_day01;第三行的Version是版本;第四行Packaging是項目打包的方式,選擇war包即可。剩下的輸入欄可以先不用管。
建完項目後,會發現項目帶了個紅叉,解決辦法是,點擊項目名稱,滑鼠右鍵,找到許多選項中的Java EE Tools,在新出現的下拉選中選擇Generate Deployment Descriptor Stub,紅叉就會消失。
2、對項目進行相關配置
首先配置jre,項目名稱右鍵,選中Build Path,在出現的下拉選中選擇Configure Build Path,首先移除舊的jre系統庫(新建maven項目預設是1.5的系統庫),點擊右邊的Add Library,在新出現的框中選擇JRE System Library,在新出現的框中找到自己對應的jre安裝路徑,點擊finish即可。
再來配置Tomcat,還是在Java Build Path的頁面,同樣點擊Add Library,在新出現的框中選擇Server Runtime,選擇你安裝好的Tomcat(文末會有一篇關於新建Maven項目的教程,可以照著步驟操作),點擊finish。
3、新建一個servlet類
在src/main/java這個文件夾下,新建一個包,我們取名servlet,在servlet包下新建一個class,名叫HelloServlet,在它的父類那裡,點擊右邊的Browse,在新彈出的框中輸入HttpServlet,選中HttpServlet,點擊ok,然後點擊finish。
重寫doGet()方法和doPost()方法。在HelloServlet類裡面,滑鼠右鍵單擊(或者快捷鍵alt+shift+s),找到Source選項,在新出現的下拉選中選擇Override/Implement Methods,在新出現的彈框中勾上doPost方法和doGet方法,點擊ok即可。
4、編寫jsp頁面
jsp頁面存放的位置在src-->main-->webapp路徑下,右鍵點擊webapp文件夾,選擇new-->other,在彈出來的框中,點開Web,選擇JSP File選項,點擊next,輸入文件名,如hello.jsp,點擊finish即可。
將頁面中存在ISO-8859-1的地方替換為UTF-8,更改編碼格式。
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>第一個servlet例子</title>
</head>
<body style="margin:50px;">
<!-- 演示get請求 -->
<a href="helloServlet">Get請求</a>
<!-- 演示post請求 -->
<form action="helloServlet" method="post">
<label>姓名</label>
<input type="text" name="name"/>
<br/>
<input type="submit" value="提交"/>
</form>
</body>
</html>
5、重寫doGet()方法和doPost()方法
/** * 第一個servlet例子 * @author 小川94 * @date 2018年6月2日 */ public class HelloServlet extends HttpServlet { private static final long serialVersionUID = 1L; @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 列印日誌 System.out.println("處理Get()請求..."); // 設置伺服器返回的數據類型 response.setContentType("text/html"); // 獲取一個輸出流 PrintWriter out = response.getWriter(); // 輸出數據,將數據發送到瀏覽器 out.println("<h1>Hello Servlet!</h1>"); // 關閉流 out.close(); } @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 列印日誌 System.out.println("處理Post()請求..."); // 對從瀏覽器獲取的數據設置編碼格式 request.setCharacterEncoding("UTF-8"); // 獲取頁面傳入的數據 String name = request.getParameter("name"); System.out.println(name); // 設置伺服器返回的數據類型 response.setContentType("text/html;charset=UTF-8"); // 獲取一個輸出流 PrintWriter out = response.getWriter(); // 輸出數據,將數據發送到瀏覽器 out.println("<h1>Hello "+name+"!</h1>"); // 關閉流 out.close(); } }
6、配置web.xml文件
在src-->main-->webapp-->WEB-INF路徑下找到web.xml文件,添加<servlet></servlet>、<servlet-mapping></servlet-mapping>標簽。
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" version="2.5"> <display-name>servlet_day01</display-name> <welcome-file-list> <welcome-file>index.html</welcome-file> <welcome-file>index.htm</welcome-file> <welcome-file>index.jsp</welcome-file> <welcome-file>default.html</welcome-file> <welcome-file>default.htm</welcome-file> <welcome-file>default.jsp</welcome-file> </welcome-file-list> <servlet> <!-- servlet別名,可以隨意定義,但是為了規範,命名要有實際意義 --> <servlet-name>hello</servlet-name> <!-- servlet類路徑,由包名.類名組成 --> <servlet-class>servlet.HelloServlet</servlet-class> </servlet> <servlet-mapping> <!-- servlet別名,可以隨意定義,但是為了規範,命名要有實際意義 --> <servlet-name>hello</servlet-name> <!-- jsp頁面請求路徑 --> <url-pattern>/helloServlet</url-pattern> </servlet-mapping> </web-app>
7、部署測試
項目名右鍵單擊,Run As --> Run on Server,在彈出的框中選擇Tomcat,點擊finish即可。
項目啟動成功後,打開瀏覽器,在地址欄輸入http://localhost:8088/servlet_day01/hello.jsp,就可以看到之前寫的jsp頁面,可以對剛剛寫的doPost()方法和doGet()方法進行測試。地址信息不要輸錯,不然會報404錯誤。
文章首發於我的個人公眾號:悅樂書。喜歡分享一路上聽過的歌,看過的電影,讀過的書,敲過的代碼,深夜的沉思。期待你的關註!
公眾號後臺輸入關鍵字“Java學習電子書”,即可獲得12本Java學習相關的電子書資源,如果經濟能力允許,還請支持圖書作者的紙質正版書籍,創作不易。