Java遇见HTML-servlet(一)

Java遇见HTML的6篇文章技术较老只是在熟悉java基础知识和了解mvc模型思想

servlet的应用

servlet可以理解为就是一个jsp,实现servlet有三步:
1、在web.xml中注册servlet,
2、在src目录下创建servlet类继承HttpServlet类,重写doGet和doPost方法,
3、然后在jsp中使用表单或者超链接等方式跳转到创建的servlet类中。

用servlet实现一个简单的功能,在界面上输入注册信息,提交后显示注册的信息。

第一步:

创建学生类实体类,与界面上要输入的字段信息对应,注意日期类型为Date,是否签协议为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;//是否接受协议

    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 +
                '}';
    }
}

第二步:创建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>
<%--创建表单,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>接受协议:</td>
            <td><input type="checkbox" name="flag">是否接受协议</td>
        </tr>
        <tr>
            <td><input type="submit" value="注册"></td>
            <%--取消type类型是reset--%>
            <td><input type="reset" value="取消"></td>
        </tr>
    </table>
</form>

</body>
</html>

第三步:写servlet类

注意是在src下创建servlet包创建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"));
        //是否签协议赋值,定义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中创建userbean时,跟id一致,这样才能在users.jsp中获取参数信息。
        req.getSession().setAttribute("getusers",users);
        //内部转发到users.jsp页面中
        req.getRequestDispatcher("../users.jsp").forward(req,resp);

    }
}

第四步:创建users.jsp

在界面上显示注册的用户信息
特别注意创建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">&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">接受协议:</td>
            <td class="content">&nbsp;<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类中重定向和内部跳转的路径

//        使用内部转发跳转到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
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容