Java 无法将JSP解析为类型

Java 无法将JSP解析为类型,java,eclipse,jsp,servlets,Java,Eclipse,Jsp,Servlets,src/movie/MovieDB.java org.apache.jasper.JasperException: Unable to compile class for JSP: An error occurred at line: 80 in the jsp file: /index.jsp movie cannot be resolved to a type 77: 78: if(movies!=null){ 79: for(int i=0;i<

src/movie/MovieDB.java

org.apache.jasper.JasperException: Unable to compile class for JSP: 

An error occurred at line: 80 in the jsp file: /index.jsp
movie cannot be resolved to a type
77:     
78:     if(movies!=null){
79:         for(int i=0;i<movies.size();i++){
80:                     movie b = (movie) movies.get(i);
81:             out.println("<tr>");
82:             out.println("<td>" + b.getMovieID() + "</td>");
83:             out.println("<td>" + b.getMovieTitle() + "</td>");
package movie;

import java.util.Date;

public class movie {

    private int MovieID;
    private String MovieTitle;
    private String Description;
    private String Image;
    private Date ReleaseDate;

    public int getMovieID() {
        return MovieID;
    }
    public void setMovieID(int movieID) {
        MovieID = movieID;
    }
    public String getMovieTitle() {
        return MovieTitle;
    }
    public void setMovieTitle(String movieTitle) {
        MovieTitle = movieTitle;
    }
    public String getDescription() {
        return Description;
    }
    public void setDescription(String description) {
        Description = description;
    }
    public String getImage() {
        return Image;
    }
    public void setImage(String image) {
        Image = image;
    }
    public Date getReleaseDate() {
        return ReleaseDate;
    }
    public void setReleaseDate(Date releaseDate) {
        ReleaseDate = releaseDate;
    }

}
    package movie;
    import java.sql.*;
    import java.util.ArrayList;

public class MovieDB {
    public ArrayList movies (String query){
        ArrayList movies= new ArrayList();

        try {
            // step 1 : load JDBC Driver
            Class.forName("com.mysql.jdbc.Driver");

            //step2 : define Connection URL
            String connURL = "jdbc:mysql://localhost:3306/sp_movie?user=root&password=root";

            //step3 establish connection url
            Connection conn = DriverManager.getConnection(connURL);

            String sql="{call "+query+"}";
            CallableStatement cs=conn.prepareCall(sql);

            ResultSet rs=cs.executeQuery();

            while(rs.next()){
                movie movies1 = new movie();
                movies1.setMovieID(rs.getInt("Movie_ID"));
                movies1.setMovieTitle(rs.getString("Movie_Title"));
                movies1.setReleaseDate(rs.getDate("Release_Date"));
                movies1.setImage(rs.getString("Image"));
                movies1.setDescription(rs.getString("Description"));

                movies.add(movies1);
            }
            } catch (Exception e){
            } finally {
                try {

                } catch (Exception e) {}
            }
            return movies;
        }
}
src/movie/Moviesearch.java

org.apache.jasper.JasperException: Unable to compile class for JSP: 

An error occurred at line: 80 in the jsp file: /index.jsp
movie cannot be resolved to a type
77:     
78:     if(movies!=null){
79:         for(int i=0;i<movies.size();i++){
80:                     movie b = (movie) movies.get(i);
81:             out.println("<tr>");
82:             out.println("<td>" + b.getMovieID() + "</td>");
83:             out.println("<td>" + b.getMovieTitle() + "</td>");
package movie;

import java.util.Date;

public class movie {

    private int MovieID;
    private String MovieTitle;
    private String Description;
    private String Image;
    private Date ReleaseDate;

    public int getMovieID() {
        return MovieID;
    }
    public void setMovieID(int movieID) {
        MovieID = movieID;
    }
    public String getMovieTitle() {
        return MovieTitle;
    }
    public void setMovieTitle(String movieTitle) {
        MovieTitle = movieTitle;
    }
    public String getDescription() {
        return Description;
    }
    public void setDescription(String description) {
        Description = description;
    }
    public String getImage() {
        return Image;
    }
    public void setImage(String image) {
        Image = image;
    }
    public Date getReleaseDate() {
        return ReleaseDate;
    }
    public void setReleaseDate(Date releaseDate) {
        ReleaseDate = releaseDate;
    }

}
    package movie;
    import java.sql.*;
    import java.util.ArrayList;

public class MovieDB {
    public ArrayList movies (String query){
        ArrayList movies= new ArrayList();

        try {
            // step 1 : load JDBC Driver
            Class.forName("com.mysql.jdbc.Driver");

            //step2 : define Connection URL
            String connURL = "jdbc:mysql://localhost:3306/sp_movie?user=root&password=root";

            //step3 establish connection url
            Connection conn = DriverManager.getConnection(connURL);

            String sql="{call "+query+"}";
            CallableStatement cs=conn.prepareCall(sql);

            ResultSet rs=cs.executeQuery();

            while(rs.next()){
                movie movies1 = new movie();
                movies1.setMovieID(rs.getInt("Movie_ID"));
                movies1.setMovieTitle(rs.getString("Movie_Title"));
                movies1.setReleaseDate(rs.getDate("Release_Date"));
                movies1.setImage(rs.getString("Image"));
                movies1.setDescription(rs.getString("Description"));

                movies.add(movies1);
            }
            } catch (Exception e){
            } finally {
                try {

                } catch (Exception e) {}
            }
            return movies;
        }
}

查看您的
电影
类定义。它被打包在
电影
包中

package movie;

import java.io.IOException;
import java.util.ArrayList;

import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * Servlet implementation class Moviesearch
 */
@WebServlet("/Moviesearch")
public class Moviesearch extends HttpServlet {
    private static final long serialVersionUID = 1L;

    /**
     * @see HttpServlet#HttpServlet()
     */
    public Moviesearch() {
        super();
        // TODO Auto-generated constructor stub
    }

    /**
     * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

        String search = (String) request.getAttribute("search");
        String searchtype = (String) request.getAttribute("searchtype");
        String query = null;

        if (searchtype.equals("title")){
            query = "titlesearch('"+search+"')";
        }else if(searchtype.equals("genre")){
            query = "genresearch('"+search+"')";
        }else if(searchtype.equals("actor")){
            query = "actorsearch('"+search+"')";
        }

        ArrayList movies = null;
        try{
            String userid = request.getParameter("userid");
            MovieDB getinfo = new MovieDB();
            movies =  getinfo.movies(query);

            request.setAttribute("movieinfo",movies);
            RequestDispatcher rd = request.getRequestDispatcher("index.jsp");
            rd.forward(request, response);
        } catch (Exception e){

        } finally {
        }

    }

    /**
     * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
    }

}
您应该将
电影
类导入为:

package movie; // full class name will be movie.movie
import java.util.Date;
public class movie { ......
}

即使这样,在JSP中编写Java代码也是非常不受鼓励的。阅读


出于您的目的,您可以使用的
循环。

是您导入的图书包中的电影类吗?@ChadNC我只导入了
我应该如何导入图书(值bean)您需要在那里进行类型声明..类似于movie-movie=(movie)movies.get(i)。更好的方法是使用泛型并定义ArrayList的类型(如ArrayList())或…最好的方法是使用EL并忘记scriplets。@MaheshGuruswamy我想我的代码也在做同样的事情
movie b=(movie)movies.get(i)?movie是一个值bean,用于存储信息表数组。如果movie类在“book”包中,那么您应该可以在jsp页面中访问它,如果它不在“book”包中,那么您还需要导入它。例子。Java是区分大小写的,因此如果类名为“Movie”,那么如果您将类名键入为“Movie”,编译器将找不到该类。谢谢您的帮助。我试过了,好像我的代码有严重错误。。