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”,编译器将找不到该类。谢谢您的帮助。我试过了,好像我的代码有严重错误。。