Java遇見HTML-servlet(一)

Java遇見HTML的6篇文章技術(shù)較老只是在熟悉java基礎(chǔ)知識(shí)和了解mvc模型思想

servlet的應(yīng)用

servlet可以理解為就是一個(gè)jsp,實(shí)現(xiàn)servlet有三步:
1、在web.xml中注冊(cè)servlet,
2、在src目錄下創(chuàng)建servlet類繼承HttpServlet類,重寫doGet和doPost方法,
3、然后在jsp中使用表單或者超鏈接等方式跳轉(zhuǎn)到創(chuàng)建的servlet類中。

用servlet實(shí)現(xiàn)一個(gè)簡單的功能,在界面上輸入注冊(cè)信息,提交后顯示注冊(cè)的信息。

第一步:

創(chuàng)建學(xué)生類實(shí)體類,與界面上要輸入的字段信息對(duì)應(yī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輸入注冊(cè)信息頁面,放到web的根目錄下

關(guān)注代碼中的注釋的點(diǎn)

<%--
  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>注冊(cè)頁面</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>確認(rèn)密碼:</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,默認(rèn)選中男,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>
                <%--復(fù)選框,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">上網(wǎng)
            </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="注冊(cè)"></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方法中調(diào)用doPost方法,要不然通過url鏈接不會(huì)走到post方法中
        doPost(req,resp);

    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

//        設(shè)置編碼為utf-8,能顯示中文
        req.setCharacterEncoding("utf-8");

        //定義users類的對(duì)象,把獲取到的參數(shù)值都賦值給該類中的屬性
        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[]獲取數(shù)值
        String[] favorite=req.getParameterValues("Favorite");
        StringBuilder favorites=new StringBuilder();
        if (favorite!=null){
            for (String s:favorite){
                favorites.append(s+",");
            }
        }

        //去掉最后一個(gè)逗號(hào)
        favorites.replace(favorites.length()-1,favorites.length()," ");
        users.setFavorite(favorites.toString());

        //自我介紹賦值
        users.setIntroduce(req.getParameter("introduce"));
        //是否簽協(xié)議賦值,定義flag標(biāo)簽,如果勾選了就代表有值設(shè)置為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());
        //把注冊(cè)成功的用戶對(duì)象存儲(chǔ)到session中,getusers要用到再users.jsp中創(chuàng)建userbean時(shí),跟id一致,這樣才能在users.jsp中獲取參數(shù)信息。
        req.getSession().setAttribute("getusers",users);
        //內(nèi)部轉(zhuǎn)發(fā)到users.jsp頁面中
        req.getRequestDispatcher("../users.jsp").forward(req,resp);

    }
}

第四步:創(chuàng)建users.jsp

在界面上顯示注冊(cè)的用戶信息
特別注意創(chuàng)建useBean時(shí),id要和userservlet類中設(shè)置session是的名稱一致,就是getusers
使用jsp動(dòng)作獲取參數(shù)值
<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類中設(shè)置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">&nbsp;<jsp:getProperty name="getusers" property="userName"/></td>
        </tr>
        <tr>
            <td class="title">密碼:</td>
            <td class="content">&nbsp;<jsp:getProperty name="getusers" property="password"/></td>
        </tr>
        <tr>
            <td class="title">電子郵箱:</td>
            <td class="content">&nbsp;<jsp:getProperty name="getusers" property="email"/></td>
        </tr>
        <tr>
            <td class="title">性別:</td>
            <td class="content">&nbsp;<jsp:getProperty name="getusers" property="sex"/></td>
        </tr>
        <tr>
            <td class="title">出生日期:</td>
            <td class="content">&nbsp;<jsp:getProperty name="getusers" property="birthday"/></td>
        </tr>
        <tr>
            <td class="title">愛好:</td>
            <td class="content">&nbsp;<jsp:getProperty name="getusers" property="favorite"/></td>
        </tr>
        <tr >
            <td class="title">自我介紹:</td>
            <td class="content">&nbsp;<jsp:getProperty name="getusers" property="introduce"/></td>
        </tr>
        <tr>
            <td class="title">接受協(xié)議:</td>
            <td class="content">&nbsp;<jsp:getProperty name="getusers" property="flag"/></td>
        </tr>
    </table>
</form>
</body>
</html>

第五步:在界面上查看結(jié)果

image.png

image.png

servlet路徑跳轉(zhuǎn)問題

總共有3處地方路徑需要關(guān)注。
1、jsp中超鏈接href路徑和表單中action跳轉(zhuǎn)路徑

<body>
<%
//    獲取當(dāng)前項(xiàng)目路徑
    String path=request.getContextPath();
%>
<%--form表單中訪問servlet路徑的寫法和超鏈接的方式是一樣的--%>
<%--使用相對(duì)路徑訪問servlet,前面不加斜杠--%>
<a href="servlet/HelloServlet">使用相對(duì)路徑訪問servlet</a><br>
<%--使用絕對(duì)路徑訪問servlet,加上path參數(shù)獲取當(dāng)前項(xiàng)目路徑--%>
<a href="<%=path%>/servlet/HelloServlet">使用絕對(duì)路徑訪問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必須以/開頭,代表項(xiàng)目的根目錄-->
        <url-pattern>/servlet/HelloServlet</url-pattern>
    </servlet-mapping>

3、servlet類中重定向和內(nèi)部跳轉(zhuǎn)的路徑

//        使用內(nèi)部轉(zhuǎn)發(fā)跳轉(zhuǎn)到result.jsp頁面,斜杠代表當(dāng)前根目錄,如果不加就找不到result.jsp文件
        req.getRequestDispatcher("/result.jsp").forward(req,resp);

//        使用重定向跳轉(zhuǎn)到result.jsp頁面
        resp.sendRedirect("/result.jsp");

        //如果jsp文件放到文件夾下,可以返回到上層目錄再到文件夾下找該jsp文件
        req.getRequestDispatcher("../testservleturl/testservletusr.jsp").forward(req,resp);
image.png

image.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,362評(píng)論 6 544
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,577評(píng)論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,486評(píng)論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,852評(píng)論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,600評(píng)論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,944評(píng)論 1 328
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,944評(píng)論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,108評(píng)論 0 290
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,652評(píng)論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,385評(píng)論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,616評(píng)論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,111評(píng)論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,798評(píng)論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,205評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,537評(píng)論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,334評(píng)論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,570評(píng)論 2 379

推薦閱讀更多精彩內(nèi)容