2 lxj0906 LXJ0906 于 2016.04.19 11:11 提问

通过Servlet显示数据库中的数据,报404
 public class userListServlet {
    public void doGet(HttpServletRequest request,HttpServletResponse response)
    throws ServletException,IOException{
        Model model=new Model();
        List<User>list=model.userSelect();
        request.getSession().setAttribute("list", list);
        response.sendRedirect("listUsers1.jsp");
    }
}


Model中的userSelect()方法如下:
public List<User> userSelect(){
        List users=new ArrayList();
        try{
            conn=s.getConncetion();
            String sql="select * from user";
            stat=conn.createStatement();
            rs=stat.executeQuery(sql);
            User user;
            while(rs.next()){
                user=new User();
                user.setId(rs.getInt("id"));
                user.setName(rs.getString("name"));
                user.setPassword(rs.getString("password"));
                users.add(user);
            }
            s.closeAll(conn, stat, rs);
        }catch(SQLException e){
            e.printStackTrace();
        }
        return users;
    }

listUsers1.jsp页面如下:
<body>
    数据库中所有用户:
    <table border="1">
        <c:forEach items="${sessionScope.list }" var="user" varStatus="num">
        <tr>
            <td>${user.id }</td>
            <td>${user.name }</td>
            <td>${user.password }</td>
        </tr>
        </c:forEach>
    </table>
</body>


web.xml配置如下:

<servlet>
        <servlet-name>userListServlet</servlet-name>
        <servlet-class>control.userListServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>userListServlet</servlet-name>
        <url-pattern>/userListServlet</url-pattern>
    </servlet-mapping>

6个回答

xujin19900128
xujin19900128   2016.04.19 11:37
已采纳

404是最基本也是最常见的错误,错误原因是访问路径错误。你没有贴出你的这个jsp页面具体是在什么路径下,还有你的浏览器中是如何输入路径的。404就
说明你输入在浏览器中的这个路径不对。这个是新手常犯的错误。
当然404错误还可能会因为是tomcat的问题,但是这个概率很小,我在工作中只碰到过一次。

CSDNXIAOD
CSDNXIAOD   2016.04.19 11:23

javaWeb使用servlet并且连接数据库向数据库插入数据
使用servlet,jdbc将mysql中数据显示在jsp页面中,且实现直接删除数据库数据
----------------------biu~biu~biu~~~在下问答机器人小D,这是我依靠自己的聪明才智给出的答案,如果不正确,你来咬我啊!

w172087242
w172087242   Ds   Rxr 2016.04.19 11:34

如果你的程序正常启动了,那么就是你的url写错了

niaonao
niaonao   Rxr 2016.04.19 12:31

404是路径错误
response.sendRedirect("listUsers1.jsp");不对
拿我的代码举个例子 :
下面有两中写法,其中一种和你的一样:

request.getRequestDispatcher("/LoginSucceed.jsp").forward(request,response);
response.sendRedirect("/test/LoginSucceed.jsp");

后者要写路径完整的工程名加上该文件名(WebRoot/ 不用写)
这是该文件的完整路径: /test/WebRoot/LoginSucceed.jsp
而前者不必写工程名

niaonao
niaonao 应该是 List<User> users=new ArrayList<User>(); 你仔细检查以下代码,其他的我也帮不了你,其他路径再查查
一年多之前 回复
niaonao
niaonao 回复LXJ0906: List<User>list=model.userSelect();   List<User> list加上空格
一年多之前 回复
niaonao
niaonao 回复LXJ0906: List<User>list=model.userSelect();   List<User> list加上空格
一年多之前 回复
LXJ0906
LXJ0906 我在前面加了工程名还是报404
一年多之前 回复
Mr_li13
Mr_li13   2016.04.19 12:48

404错误在客户端,客户端都没有通过域名解析,当然报错了。自习瞧瞧你的前端。

qq_23254453
qq_23254453   2016.04.19 18:47

404路径错误,url看看请求地址

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!