会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132360个问题

webdemo.rar

blob.pngblob.pngblob.pngblob.pngblob.pngblob.png老师,这输入正确的用户名和密码也一直报错,老师您看是什么问题,怎么解决呢

JAVA 全系列/第五阶段:JavaWeb开发/Web实战案例 1021楼
JAVA 全系列/第五阶段:JavaWeb开发/Servlet技术详解(旧) 1022楼
JAVA 全系列/第五阶段:JavaWeb开发/Servlet技术详解(旧) 1023楼

servletdemo.zip

老师您看下我的代码屏幕截图 2021-03-31 193620.png

JAVA 全系列/第五阶段:JavaWeb开发/Servlet技术详解(旧) 1024楼
JAVA 全系列/第五阶段:JavaWeb开发/Servlet技术详解(旧) 1025楼

老师帮忙看看,添加不进去数据

users

package com.bjsxt.pojo;

import com.fasterxml.jackson.annotation.JsonFormat;

import java.util.Date;

//创建项目的Users类
public class Users {
    private int userid;

    public int getUserid() {
        return userid;
    }

    public void setUserid(int userid) {
        this.userid = userid;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getUsersex() {
        return usersex;
    }

    public void setUsersex(String usersex) {
        this.usersex = usersex;
    }

    public Date getUserbirth() {
        return userbirth;
    }

    public void setUserbirth(Date userbirth) {
        this.userbirth = userbirth;
    }

    private String username;
    private String usersex;
    //指定显示格式
    @JsonFormat(pattern = "yyyy-MM-dd",timezone = "GMT + 8")
    private Date userbirth;
}

servlet

package com.bjsxt.servlet;

import com.bjsxt.common.JsonUtils;
import com.bjsxt.pojo.Users;
import org.omg.PortableServer.LIFESPAN_POLICY_ID;

import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.awt.*;
import java.io.IOException;
import java.io.PrintWriter;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;

//用户管理Servlet
@WebServlet("/users.do")
public class UsersServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        this.doPost(req, resp);
    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        String flag = req.getParameter("flag");
        if ("getData".equals(flag)) {
            this.getData(req, resp);
            //判断flag是否为addUser
        } else if ("addUser".equals(flag)) {
            this.addUser(req, resp);
        }
    }

    private void getData(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //获得页面初始化数据
        List<Users> list = (List<Users>) this.getServletContext().getAttribute("list");
        String s = JsonUtils.objectToJson(list);
        resp.setContentType("application/json");
        PrintWriter pw = resp.getWriter();
        pw.print(s);
        pw.flush();
        pw.close();

    }

    //添加用户的方法
    private void addUser(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //首先调用获取数据的方法
        Users date = this.getDate(req);
        ServletContext servletContext = this.getServletContext();
        List<Users> list = (List<Users>) this.getServletContext().getAttribute("list");
        list.add(date);
        //设置提示信息的响应格式
        resp.setContentType("text/plain;charset=utf-8");
        PrintWriter pw = resp.getWriter();
        pw.print("添加成功!");
        pw.flush();
        pw.close();
    }

    //生成模拟数据初始化
    @Override
    public void init() throws ServletException {
        Users user = new Users();
        user.setUserid(1);
        user.setUsername("cheng");
        user.setUsersex("man");
        user.setUserbirth(new Date());
        Users user2 = new Users();
        user2.setUserid(2);
        user2.setUsername("jun");
        user2.setUsersex("man");
        user2.setUserbirth(new Date());
        //创建数组,进行数据的存放
        List<Users> list = new ArrayList<>();
        list.add(user);
        list.add(user2);
        ServletContext servletContext = this.getServletContext();
        //添加数据
        servletContext.setAttribute("list", list);
    }

    //获取请求数据
    private Users getDate(HttpServletRequest req) {
        String userid = req.getParameter("userid");
        String username = req.getParameter("username");
        String usersex = req.getParameter("usersex");
        String userbirth = req.getParameter("userbirth");
        //创建对象,添加获取的数据
        Users users = new Users();
        users.setUserid(Integer.parseInt(userid));
        users.setUsername(username);
        users.setUsersex(usersex);
        //进行格式的规定
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
        try {
            //格式转化
            Date parse = sdf.parse(userbirth);
            //添加信息
            users.setUserbirth(parse);
        } catch (ParseException e) {
            e.printStackTrace();
        }
        //返回Users对象
        return users;
    }
}

jsp

<%--
  Created by IntelliJ IDEA.
  User: 
  Date: 2021/3/30
  Time: 11:48
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>用户管理</title>
    <%--    引入样式--%>
    <script src="js/jquery.js"></script>
    <script>
        $(function () {
            //获取初始化数据
            getDate();
            //添加用户绑定事件
            $("#add").click(function () {
                addOrUpdateUser("addUser");
            })
        });

        //定义获得数据
        function getDate() {
            $.getJSON("users.do", {flag: "getData"}, function (result) {
                init(result);
            })
        }

        //遍历数组生成数据
        function init(obj) {
            var str = "";
            $.each(obj, function () {
                str += "<tr align='center'><td id='" + this.userid + "'>" + this.userid + "</td><td>" + this.username + "</td><td>" + this.usersex + "</td><td>" + this.userbirth + "</td><td><a href='#' onclick='preUpdateUser()'>选择更新</a>&nbsp;&nbsp;&nbsp;<a href='#' onclick='deleteUser(" + this.userid + ")'>删除</a></td></tr>"
            });
            //拼接字符串
            $("#tBody").prepend(str);
        }

        //添加用户或者是用户更新数据事件方法
        function addOrUpdateUser(flag) {
            //获取数据
            var userid = $("#userid").val();
            var username = $("#username").val();
            var usersex = $("#usersex").val();
            var userbirth =$("#userbirth").val();
            var date = {
                userid:userid,
                username:username,
                usersex:usersex,
                userbirth:userbirth,
                flag:flag
            }
            //刷新页面
            location.reload();
            $.get("user.do",date,function (result){
                alert(result);
            });
        }
    </script>
</head>
<body>
<table align="center" width="60%" border="1">
    <tr>
        <td>ID:</td>
        <td><input type="text" name="userid" id="userid"/></td>
        <td>姓名:</td>
        <td><input type="text" name="username" id="username"/></td>
    </tr>
    <tr>
        <td>性别:</td>
        <td><input type="text" name="usersex" id="usersex"/></td>
        <td>生日:</td>
        <td><input type="text" name="userbirth"
                   id="userbirth"/></td>
    </tr>
    <tr align="center">
        <td colspan="4">
            <input type="button" value="添加用户" id="add"/>18
            <input type="button" value="更新用户" id="update"/>
        </td>
    </tr>
</table>
<hr/>
<table align="center" width="60%" bgcolor="" border="1"
       id="myTable">
    <thead>
    <tr align="center">
        <td>ID</td>
        <td>姓名</td>
        <td>性别</td>
        <td>生日</td>
        <td>操作</td>
    </tr>
    </thead>
    <tbody id="tBody"></tbody>
</table>
</body>
</html>


JAVA 全系列/第五阶段:JavaWeb开发/Ajax技术详解(旧) 1026楼
JAVA 全系列/第五阶段:JavaWeb开发/Ajax技术详解(旧) 1027楼

servletdemo.zip

老师,帮我看下。

image.png

JAVA 全系列/第五阶段:JavaWeb开发/Servlet技术详解(旧) 1029楼

文件上传成功了,可以在文件夹里找到文件,但是不显示上传成功信息,反而弹出下载fileUpload.do文件,这是什么原因啊?

package com.example.ServletDemo.part;

import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.MultipartConfig;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.Part;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.UUID;

@WebServlet(name = "FileUploadServlet", value = "/fileUpload.do") @MultipartConfig public class FileUploadServlet
    extends HttpServlet {
    @Override protected void doGet(HttpServletRequest request, HttpServletResponse response)
        throws ServletException, IOException {
        this.doPost(request, response);

    }

    @Override protected void doPost(HttpServletRequest request, HttpServletResponse response)
        throws ServletException, IOException {

        response.setContentType("describe/html;charset=utf-8");
        String describe = request.getParameter("describe");
        Part uploadFile = request.getPart("uploadFile");// 要与<input>中的name一致

        // 获取文件上传的字节流
        // InputStream inputStream = uploadFile.getInputStream();
        // 给文件改名
        String fileName = UUID.randomUUID().toString() + uploadFile.getSubmittedFileName()
            .substring(uploadFile.getSubmittedFileName().lastIndexOf("."));
        // 路径转换
        ServletContext servletContext = this.getServletContext();
        String realPath = servletContext.getRealPath("image/" + fileName);
        // 直接调用Part对象的write方法,不用手动创建字节流
        uploadFile.write(realPath);
        PrintWriter out = response.getWriter();
        out.println("<html><body>");
        out.println("上传成功!" + describe);
        out.println("</body></html>");
        out.flush();
        out.close();
    }
}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<form action="fileUpload.do" method="post" enctype="multipart/form-data">
    文件描述:<input type="text" name="describe"/>
    上传文件:<input type="file" name="uploadFile"/><br/>
    <input type="submit" value="submit"/>
</form>
</body>
</html>

image.png

JAVA 全系列/第五阶段:JavaWeb开发/Servlet技术详解(旧) 1031楼

image.png

apache-tomcat-9.0.34.rar


老师我配置跟视频中的一样,我说什么就找不到资源呀?

JAVA 全系列/第五阶段:JavaWeb开发/Servlet技术详解(旧) 1032楼
JAVA 全系列/第五阶段:JavaWeb开发/Servlet技术详解(旧) 1033楼
JAVA 全系列/第五阶段:JavaWeb开发/Servlet技术详解(旧) 1035楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637