《web应用技术》第一次课后练习

文章介绍了如何用JSP进行用户输入操作的获取(如姓名、性别、爱好和邮箱),以及用户登录验证功能,包括错误处理和权限控制。通过设置Cookie来存储用户信息,实现登录状态的检测。
摘要由CSDN通过智能技术生成

练习1:

用JSP实现用户获取用户输入的操作。(仿教材例5-5)

源代码

input.jsp

<%@ page contentType="text/html;charset=GBK" language="java" %>
<html>
<head>
    <title>input</title>
</head>
<body>
<form action="output.jsp" method="post">
    <ul style="list-style:none;line-height: 30px">
        <li>姓名:
            <input type="text" name="name"><br>
        </li>
        <li>性别:
            <input name="sex" type="radio" value="男">男&nbsp;
            <input name="sex" type="radio" value="女">女
        </li>
        <li>爱好:
            <input name="like" type="checkbox" value="篮球">篮球&nbsp;
            <input name="like" type="checkbox" value="旅游">旅游&nbsp;
            <input name="like" type="checkbox" value="音乐">音乐&nbsp;
            <input name="like" type="checkbox" value="摄影">摄影
        </li>
        <li>E-mail:
            <input type="text" name="email">
        </li>
        <li>
            <input type="submit" value="提交">
            <input type="reset" value="重置">
        </li>
    </ul>
</form>
</body>
</html>

output.jsp

<%@ page contentType="text/html;charset=GBK" language="java" %>
<html>
<head>
    <title>output</title>
</head>
<body>
<ul style="list-style:none;line-height: 30px">
    <li>姓名:
        <%=new String(request.getParameter("name").getBytes("ISO8859_1"),"GBK")%>
    </li>
    <li>性别:
        <%=new String(request.getParameter("sex").getBytes("ISO8859_1"),"GBK")%>
    </li>
    <li>爱好:
        <%
            String[] like=request.getParameterValues("like");
            for(int i=0;i<like.length;i++){
        %>
        <%=new String(like[i].getBytes("ISO8859_1"),"GBK")+"&nbsp;&nbsp;"%>
        <%
            }
        %>
    </li>
    <li>E-mail:
        <%=new String(request.getParameter("email").getBytes("ISO8859_1"),"GBK")%>
    </li>
</ul>
</body>
</html>

运行结果

练习2

用JSP实现用户登录验证的功能。

  • 如果用户输入正确的账号密码,则提示问候语句;如果用户输入错误的账号密码,则提示账号密码有误。
  • 任意编写3-4个页面,为每个页面添加权限控制。如果用户已经登录,则在每个页面页首提示:欢迎你,**。如果没有登录跳转到这个页面,则提示:非法访问

源代码

log_index.jsp

<%@ page contentType="text/html;charset=GBK" language="java" %>
<%
    String actionURL="log_index.jsp";
    String[]info=new String[]{"",""};
    String str=request.getParameter("username");
    String pwd=request.getParameter("pwd");
    if(null!=str){
        if(str.equals("tom")&&pwd.equals("123456")){
            out.println("你好,tom");
            actionURL="log_show.jsp";
            Cookie mycook=new Cookie("mr",str+"#"+pwd);
            info=mycook.getValue().split("#");
            mycook.setMaxAge(10);
            response.addCookie(mycook);
        }
        else{
            out.println("您输入的账号密码有误,请重新输入!");
        }
    }
%>
<html>
<head>
    <title>Title</title>
</head>
<body>
<%

%>
    <form action="<%=actionURL%>" method="post">
        账号:<input type="text" name="username" value="<%=info[0]%>"><br>
        密码: <input type="text" name="pwd" value="<%=info[1]%>"><br>
        <input type="submit" value="登录">
    </form>
</body>
</html>

log_show.jsp

<%@ page contentType="text/html;charset=GBK" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<%
  String str=request.getParameter("username");
  Cookie[] cook=request.getCookies();
  String welcome="非法访问";
  if(cook!=null) {
   for(int i=0;i<cook.length;i++){
     if(cook[i].getName().equals("mr")){
       if(str!=null)
       welcome=str+",欢迎您!";
     }
   }
  }
%>
<%=welcome%>
<div style="text-align: center">
  <h3>静夜思</h3>
  <p>床前明月光,疑是地下霜。</p>
  <p>举头望明月,低头思故乡。</p>
</div>
</body>
</html>

运行结果:

  • 6
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值