Java遇見HTML的6篇文章技術較老只是在熟悉java基礎知識和了解mvc模型思想
servlet的應用
servlet可以理解為就是一個jsp,實現servlet有三步:
1、在web.xml中注冊servlet,
2、在src目錄下創(chuàng)建servlet類繼承HttpServlet類,重寫doGet和doPost方法,
3肥哎、然后在jsp中使用表單或者超鏈接等方式跳轉到創(chuàng)建的servlet類中。
用servlet實現一個簡單的功能疾渣,在界面上輸入注冊信息篡诽,提交后顯示注冊的信息。
第一步:
創(chuàng)建學生類實體類,與界面上要輸入的字段信息對應榴捡,注意日期類型為Date杈女,是否簽協(xié)議為Boolean類型,該類放到src目錄的com.zhidaoauto.model包下吊圾。
package com.zhidaoauto.model;
import java.util.Date;
public class Users {
private String UserName;//用戶名
private String Password;//密碼
private String Email;//郵箱
private String Sex;//性別
private Date Birthday;//日期
private String Favorite;//愛好
private String introduce;//介紹
private Boolean flag;//是否接受協(xié)議
public Users(){
}
public String getUserName() {
return UserName;
}
public void setUserName(String userName) {
UserName = userName;
}
public String getPassword() {
return Password;
}
public void setPassword(String password) {
Password = password;
}
public String getEmail() {
return Email;
}
public void setEmail(String email) {
Email = email;
}
public String getSex() {
return Sex;
}
public void setSex(String sex) {
Sex = sex;
}
public Date getBirthday() {
return Birthday;
}
public void setBirthday(Date birthday) {
Birthday = birthday;
}
public String getFavorite() {
return Favorite;
}
public void setFavorite(String favorite) {
Favorite = favorite;
}
public String getIntroduce() {
return introduce;
}
public void setIntroduce(String introduce) {
this.introduce = introduce;
}
public Boolean getFlag() {
return flag;
}
public void setFlag(Boolean flag) {
this.flag = flag;
}
@Override
public String toString() {
return "Users{" +
"UserName='" + UserName + '\'' +
", Password='" + Password + '\'' +
", Email='" + Email + '\'' +
", Sex='" + Sex + '\'' +
", Birthday=" + Birthday +
", Favorite='" + Favorite + '\'' +
", introduce='" + introduce + '\'' +
", flag=" + flag +
'}';
}
}
第二步:創(chuàng)建reg.jsp輸入注冊信息頁面达椰,放到web的根目錄下
關注代碼中的注釋的點
<%--
Created by IntelliJ IDEA.
User: Administrator
Date: 2020/4/26
Time: 16:16
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>注冊頁面</title>
</head>
<body>
<%--創(chuàng)建表單,action指向servlet類--%>
<form action="/servlet/userservlet" method="post">
<table>
<tr>
<td>用戶名:</td>
<td><input type="text" name="UserName"></td>
</tr>
<tr>
<td>密碼:</td>
<td><input type="password" name="Password"></td>
</tr>
<tr>
<td>確認密碼:</td>
<td><input type="password" name="assertPassword"></td>
</tr>
<tr>
<td>電子郵箱:</td>
<td><input type="text" name="Email"></td>
</tr>
<tr>
<td>性別:</td>
<td>
<%--是單選框项乒,type是radio,默認選中男,checked="checked"--%>
<input type="radio" name="Sex" checked="checked" value="男">男
<input type="radio" name="Sex" value="女">女
</td>
</tr>
<tr>
<td>出生日期:</td>
<%--日期格式啰劲,type=date--%>
<td><input type="date" name="Birthday"></td>
</tr>
<tr>
<td>愛好:</td>
<td>
<%--復選框,name都相同檀何,value值不同--%>
<input type="checkbox" name="Favorite" value="NBA">NBA
<input type="checkbox" name="Favorite" value="music">音樂
<input type="checkbox" name="Favorite" value="moive">電影
<input type="checkbox" name="Favorite" value="internet">上網
</td>
</tr>
<tr >
<td>自我介紹:</td>
<td><input type="text" name="introduce"></td>
</tr>
<tr>
<td>接受協(xié)議:</td>
<td><input type="checkbox" name="flag">是否接受協(xié)議</td>
</tr>
<tr>
<td><input type="submit" value="注冊"></td>
<%--取消type類型是reset--%>
<td><input type="reset" value="取消"></td>
</tr>
</table>
</form>
</body>
</html>
第三步:寫servlet類
注意是在src下創(chuàng)建servlet包創(chuàng)建userservlet類蝇裤,該類繼承HttpServlet類。
package servlet;
import com.zhidaoauto.model.Users;
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.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class userservlet extends HttpServlet {
// 按Alt+Insert快捷鍵频鉴,重寫doGet和doPost方法
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// doGet方法中調用doPost方法栓辜,要不然通過url鏈接不會走到post方法中
doPost(req,resp);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// 設置編碼為utf-8,能顯示中文
req.setCharacterEncoding("utf-8");
//定義users類的對象垛孔,把獲取到的參數值都賦值給該類中的屬性
Users users=new Users();
users.setUserName(req.getParameter("UserName"));//用戶名賦值
users.setPassword(req.getParameter("Password"));//密碼賦值
users.setEmail(req.getParameter("Email"));//郵箱賦值
users.setSex(req.getParameter("Sex"));//性別賦值
//出生日期賦值
SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd");
try {
Date date=sdf.parse(req.getParameter("Birthday"));
users.setBirthday(date);
} catch (ParseException e) {
e.printStackTrace();
}
//愛好賦值狈邑,是checkbox類型橘蜜,用string[]獲取數值
String[] favorite=req.getParameterValues("Favorite");
StringBuilder favorites=new StringBuilder();
if (favorite!=null){
for (String s:favorite){
favorites.append(s+",");
}
}
//去掉最后一個逗號
favorites.replace(favorites.length()-1,favorites.length()," ");
users.setFavorite(favorites.toString());
//自我介紹賦值
users.setIntroduce(req.getParameter("introduce"));
//是否簽協(xié)議賦值子房,定義flag標簽饲宛,如果勾選了就代表有值設置為true,沒勾選就為false
boolean flag=false;
String[] flags=req.getParameterValues("flag");
if (flags!=null){
flag=true;
}else {
flag=false;
}
users.setFlag(flag);
System.out.println(users.toString());
//把注冊成功的用戶對象存儲到session中概作,getusers要用到再users.jsp中創(chuàng)建userbean時腋妙,跟id一致,這樣才能在users.jsp中獲取參數信息仆嗦。
req.getSession().setAttribute("getusers",users);
//內部轉發(fā)到users.jsp頁面中
req.getRequestDispatcher("../users.jsp").forward(req,resp);
}
}
第四步:創(chuàng)建users.jsp
在界面上顯示注冊的用戶信息
特別注意創(chuàng)建useBean時辉阶,id要和userservlet類中設置session是的名稱一致先壕,就是getusers
使用jsp動作獲取參數值
<jsp:getProperty name="getusers" property="userName"/>
<%--
Created by IntelliJ IDEA.
User: Administrator
Date: 2020/4/26
Time: 16:17
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%--id要和userservlet類中設置session是的名稱一致瘩扼,就是getusers--%>
<jsp:useBean id="getusers" scope="session" class="com.zhidaoauto.model.Users"/>
<html>
<head>
<title>展示用戶信息</title>
</head>
<body>
<form action="servlet/userservlet" method="post">
<table>
<tr>
<td class="title">用戶名:</td>
<td class="content"> <jsp:getProperty name="getusers" property="userName"/></td>
</tr>
<tr>
<td class="title">密碼:</td>
<td class="content"> <jsp:getProperty name="getusers" property="password"/></td>
</tr>
<tr>
<td class="title">電子郵箱:</td>
<td class="content"> <jsp:getProperty name="getusers" property="email"/></td>
</tr>
<tr>
<td class="title">性別:</td>
<td class="content"> <jsp:getProperty name="getusers" property="sex"/></td>
</tr>
<tr>
<td class="title">出生日期:</td>
<td class="content"> <jsp:getProperty name="getusers" property="birthday"/></td>
</tr>
<tr>
<td class="title">愛好:</td>
<td class="content"> <jsp:getProperty name="getusers" property="favorite"/></td>
</tr>
<tr >
<td class="title">自我介紹:</td>
<td class="content"> <jsp:getProperty name="getusers" property="introduce"/></td>
</tr>
<tr>
<td class="title">接受協(xié)議:</td>
<td class="content"> <jsp:getProperty name="getusers" property="flag"/></td>
</tr>
</table>
</form>
</body>
</html>
第五步:在界面上查看結果
image.png
image.png
servlet路徑跳轉問題
總共有3處地方路徑需要關注谆甜。
1、jsp中超鏈接href路徑和表單中action跳轉路徑
<body>
<%
// 獲取當前項目路徑
String path=request.getContextPath();
%>
<%--form表單中訪問servlet路徑的寫法和超鏈接的方式是一樣的--%>
<%--使用相對路徑訪問servlet集绰,前面不加斜杠--%>
<a href="servlet/HelloServlet">使用相對路徑訪問servlet</a><br>
<%--使用絕對路徑訪問servlet规辱,加上path參數獲取當前項目路徑--%>
<a href="<%=path%>/servlet/HelloServlet">使用絕對路徑訪問servlet</a>
</body>
2、web.xml中url-pattern的路徑
<servlet>
<servlet-name>Faces Servlet</servlet-name>
<servlet-class>servlet.HelloServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<!--url-pattern必須以/開頭栽燕,代表項目的根目錄-->
<url-pattern>/servlet/HelloServlet</url-pattern>
</servlet-mapping>
3罕袋、servlet類中重定向和內部跳轉的路徑
// 使用內部轉發(fā)跳轉到result.jsp頁面,斜杠代表當前根目錄碍岔,如果不加就找不到result.jsp文件
req.getRequestDispatcher("/result.jsp").forward(req,resp);
// 使用重定向跳轉到result.jsp頁面
resp.sendRedirect("/result.jsp");
//如果jsp文件放到文件夾下浴讯,可以返回到上層目錄再到文件夾下找該jsp文件
req.getRequestDispatcher("../testservleturl/testservletusr.jsp").forward(req,resp);
image.png
image.png