会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132849个问题
JAVA 全系列/第五阶段:JavaWeb开发/Web实战案例 797楼

老师,在没有添加过滤器的时候,项目默认会执行index.jsp,但是当我添加了过滤器后就会默认执行登录页面,即使我再代码中对获得的URL中的index.jsp放行了,也还是不行,最后我发现在URL中根本就没有index.jsp,所以才会去执行请求转发。这是为什么?

package com.example.filter;

import com.example.pojo.Users;

import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;
import java.io.IOException;

@WebFilter(urlPatterns = {"*.jsp","*.do"})
public class UserLoginFilter implements Filter {
    /**
     *
     * @param filterConfig
     * @throws ServletException
     *
     * 用于实现用户登录的过滤器
     * 可以对所有得动态资源进行过滤,对静态资源进行放行,同时对用户的登录的.jsp或者.do资源进行放行
     *
     */
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {

    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {

        /**
         * 对象的转换
         */
        HttpServletRequest request = (HttpServletRequest) servletRequest;

        StringBuffer requestURL = request.getRequestURL();

        /**
         * 对路径进行判断,如果是登录的请求,就去放行,否则,就是过滤
         */
        if (requestURL.indexOf("index.jsp") != -1 || requestURL.indexOf("UserLogin.jsp") != -1 || requestURL.indexOf("UserLogin.do") != -1) {

            filterChain.doFilter(servletRequest, servletResponse);

        } else {

            /**
             * 当走到else时,就表示,当前访问的不是这个登录的动态资源,那就要对你当前这个用户状态进行选择判断,
             * 如果,有sessionID就是登陆过的,否则,就是没有登陆过的。
             */
            HttpSession session = request.getSession();

            Users users = (Users) session.getAttribute("users");

            if (users != null) {
                /**
                 * 登录了,就进行放行
                 */
                filterChain.doFilter(servletRequest, servletResponse);
            } else {
                /**
                 * 没有登录就提示
                 */
                session.setAttribute("NotLoginMsg","您还没有登录请先进行登录...");
                request.getRequestDispatcher("UserLogin.jsp").forward(servletRequest, servletResponse);
            }

        }


    }

    @Override
    public void destroy() {

    }
}

image.png



我若是将Content-path写成:

/ProjectDemo_two/index.jsp

也不合适,




JAVA 全系列/第五阶段:JavaWeb开发/Web实战案例 798楼

package com.example.dao.DaoImpl;

import com.example.dao.DaoInterface.Dao_UserLoginInterface;
import com.example.pojo.Users;
import com.example.utils.JdbcUtils;

import java.sql.*;

public class Dao_UserLoginImplClass implements Dao_UserLoginInterface {

    /**
     * 用户登录数据库查询
     * @param username
     * @param userpwd
     * @return
     */

    @Override
    public Users SelectUserByUserNameAndUserPwd(String username, String userpwd) {

        Users user = null;
        Connection conn = null;
        PreparedStatement ps = null;
        ResultSet rs = null;
        try{
            System.out.println(1);//用于定位
            conn = JdbcUtils.JDBC_Connection();
            System.out.println(2);//用于定位
            ps = conn.prepareStatement("select * from oneselfproject.user where user.UserID = ? and user.UserName = ?");
            System.out.println(3);//用于定位
            ps.setString(1,username);
            ps.setString(2,userpwd);
            System.out.println(4);//用于定位
            rs= ps.executeQuery();
            System.out.println(5);//用于定位
            while (rs.next()){
                user = new Users();
                user.setUserID(rs.getString("UserID"));
                user.setUserName(rs.getString("UserName"));
                user.setUserEmial(rs.getString("UserEmial"));
            }
        }catch (Exception e){
            e.printStackTrace();
        }finally {
            JdbcUtils.JDBC_Release_Resources(conn,ps,rs);
        }
        return user;
    }
}

老师,dao层的代码,我现在连接数据库有问题。我对他进行定位,发现现在在这里出现了问题,导致返回的对象都是null;

ps = conn.prepareStatement("select * from oneselfproject.user where user.UserID = ? and user.UserName = ?");



报错的结果:

[2021-08-03 11:54:10,892] Artifact OneSelfProject_Test:war exploded: Artifact is deployed successfully
[2021-08-03 11:54:10,892] Artifact OneSelfProject_Test:war exploded: Deploy took 23,134 milliseconds
1
2
java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
	at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1364)
	at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1187)
	at java.lang.Class.forName0(Native Method)
	at java.lang.Class.forName(Class.java:264)
	at com.example.utils.JdbcUtils.<clinit>(JdbcUtils.java:29)
	at com.example.dao.DaoImpl.Dao_UserLoginImplClass.SelectUserByUserNameAndUserPwd(Dao_UserLoginImplClass.java:27)
	at com.example.service.ServiceImpl.Service_UserLoginImplClass.ServiceUserLoginClass(Service_UserLoginImplClass.java:13)
	at com.example.servlet.Login.UserLoginServlet.doPost(UserLoginServlet.java:37)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:652)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:733)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162)
	at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162)
	at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:202)
	at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97)
	at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:542)
	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:143)
	at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
	at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:687)
	at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78)
	at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:346)
	at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:374)
	at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
	at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:887)
	at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1684)
	at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
	at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
	at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
	at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
	at java.lang.Thread.run(Thread.java:748)
java.sql.SQLException: No suitable driver found for jdbc:mysql://localhost:3306/oneselfproject?useUnicode=true&characterEncoding=utf8
	at java.sql.DriverManager.getConnection(DriverManager.java:689)
	at java.sql.DriverManager.getConnection(DriverManager.java:247)
	at com.example.utils.JdbcUtils.JDBC_Connection(JdbcUtils.java:42)
	at com.example.dao.DaoImpl.Dao_UserLoginImplClass.SelectUserByUserNameAndUserPwd(Dao_UserLoginImplClass.java:27)
	at com.example.service.ServiceImpl.Service_UserLoginImplClass.ServiceUserLoginClass(Service_UserLoginImplClass.java:13)
	at com.example.servlet.Login.UserLoginServlet.doPost(UserLoginServlet.java:37)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:652)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:733)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162)
	at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162)
	at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:202)
	at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97)
	at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:542)
	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:143)
	at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
	at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:687)
	at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78)
	at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:346)
	at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:374)
	at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
	at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:887)
	at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1684)
	at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
	at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
	at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
	at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
	at java.lang.Thread.run(Thread.java:748)
java.lang.NullPointerException
	at com.example.dao.DaoImpl.Dao_UserLoginImplClass.SelectUserByUserNameAndUserPwd(Dao_UserLoginImplClass.java:29)
	at com.example.service.ServiceImpl.Service_UserLoginImplClass.ServiceUserLoginClass(Service_UserLoginImplClass.java:13)
	at com.example.servlet.Login.UserLoginServlet.doPost(UserLoginServlet.java:37)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:652)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:733)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:227)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162)
	at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:189)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:162)
	at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:202)
	at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:97)
	at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:542)
	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:143)
	at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
	at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:687)
	at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:78)
	at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:346)
	at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:374)
	at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
	at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:887)
	at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1684)
	at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
	at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
	at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
	at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
	at java.lang.Thread.run(Thread.java:748)

为什么在这里会出现这种问题???

JAVA 全系列/第五阶段:JavaWeb开发/Web实战案例 799楼

ajaxdemo.rar

老师是我ajax案例的文件,麻烦看一下,没有用户信息出来,而且也不报错误,无从下手

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



老师,请你帮我看一下我的项目,始终都是出现错误,走的一直是error.jsp页面

OneSelfProject_Test.zip

image.png

数据库内容及代码;


image.png


image.png




数据库备份,文件格式不支持,就不上传文件了,

/*
SQLyog 企业版 - MySQL GUI v8.14 
MySQL - 5.7.19 : Database - oneselfproject
*********************************************************************
*/


/*!40101 SET NAMES utf8 */;

/*!40101 SET SQL_MODE=''*/;

/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;
CREATE DATABASE /*!32312 IF NOT EXISTS*/`oneselfproject` /*!40100 DEFAULT CHARACTER SET utf8 */;

USE `oneselfproject`;

/*Table structure for table `user` */

DROP TABLE IF EXISTS `user`;

CREATE TABLE `user` (
  `UserID` varchar(20) NOT NULL,
  `UserName` varchar(20) NOT NULL,
  `UserEmial` varchar(20) NOT NULL,
  PRIMARY KEY (`UserID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

/*Data for the table `user` */

insert  into `user`(`UserID`,`UserName`,`UserEmial`) values ('191340065','HUIDOU','2195592699@QQ.COM'),('191340128','LIZIYING','4537535634@QQ.COM');

/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
/*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;




JAVA 全系列/第五阶段:JavaWeb开发/Web实战案例 801楼
JAVA 全系列/第五阶段:JavaWeb开发/JSP技术详解(旧) 806楼

package com.example.Jsp;

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.io.IOException;

@WebServlet("/language.do")
public class LanguageJsp extends HttpServlet {
    /**
     *
     * @param req
     * @param resp
     * @throws ServletException
     * @throws IOException
     *
     * 实现一个Servlet执行一个请求转发,基于Jsp页面显示数据内容
     */

    @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 header = req.getHeader("Accept-Language");

        req.setAttribute("key",header);

        req.getRequestDispatcher("LanguageDisplay.jsp");

    }
}
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
    <%
        String key = (String) request.getAttribute("key");
    %>
    浏览器支持的语言为:<%= key%>
</body>
</html>


老师,我在这里面做了一个尝试,就是在请求转发时,我不重传req和resp对象

image.png



我的理解是,我尝试不传对象,那么在新的jsp页面中,自己本身的request对象就是null,就算显示不出来key数据,也应该显示出来的结果为:

浏览器支持的语言为:null

但是我发现当我输入content-path为:http://localhost:8080/Jsp/language.do时  我的浏览器,显示的页面是空的;但是当我输入:http://localhost:8080/Jsp/LanguageDisplay.jsp时,显示的确实是

浏览器支持的语言为:null

为什么?求解

JAVA 全系列/第五阶段:JavaWeb开发/JSP技术详解(旧) 807楼
JAVA 全系列/第五阶段:JavaWeb开发/Web实战案例 808楼

webdemo.rar

老师,我也遇到了和大部分同学一样的问题,登录之后,一直显示用户名或密码有误,帮我看看哪里有问题

image.png

image.png

JAVA 全系列/第五阶段:JavaWeb开发/Web实战案例 810楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

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