- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在学习如何将 jdbc 与 jsp 结合使用,并且遇到了一个问题,我一直试图解决但无济于事,希望有人可以提供一些见解。我的问题是,由于某种原因,明星列表对象最终为空,而流派列表则很好。我可以根据用户输入看到所选类型的电影类型,但每部电影的相关明星不会显示。我怀疑这可能是因为我的功能是从列表中搜索星星。我会尝试调试并找到错误,但是我建立tomcat和eclipse的方法以及我对此类编程的缺乏知识使得它变得非常困难。如有任何帮助,我们将不胜感激,谢谢。 output of jsp
`
public class GenreServlet extends HttpServlet
{
String query;
List<Genre> genreList;
List<Movie> genreSelect;
List<Star> starSelect;
@Override
public void init(ServletConfig config) throws ServletException
{
query = null;
genreList = null;
genreSelect = null;
ServletContext context = config.getServletContext();
context.getRequestDispatcher("/jsp/genrelist.jsp");
}
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException
{
query = req.getParameter("query");
if(query == null)
{
try
{
genreList = new GenreDAO().genreList();
}
catch (Exception e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
req.getSession().setAttribute("genres", genreList);
req.getRequestDispatcher("/jsp/genrelist.jsp").forward(req, resp);
}
else
{
try
{
genreSelect = new MovieDAO().findMoviesFromGenre(query);
starSelect = new StarDAO().findStarsFromMovies(genreSelect);
}
catch(Exception e)
{
e.printStackTrace();
}
req.getSession().setAttribute("movies", genreSelect);
req.getSession().setAttribute("starlist", starSelect);
req.getRequestDispatcher("/jsp/movielist.jsp").forward(req, resp);
}
}
}
`
public class StarDAO
{
public List<Star> findStarsFromMovies(List<Movie> movieList) throws Exception
{
List<Star> result = new ArrayList<Star>();
String driver = "com.mysql.jdbc.Driver";
String url = "jdbc:mysql://localhost:3306/";
String dbName = "moviedb";
String user = "andrew";
String password = "bg79jd7c";
String sql = "select * from stars where id in (select star_id from stars_in_movies where"
+ " movie_id in (select id from movies where title = ?));";
Connection connection = null;
PreparedStatement statement = null;
ResultSet resultSet = null;
for(Movie movie: movieList)
{
try
{
Class.forName(driver).newInstance();
connection = DriverManager.getConnection(url + dbName, user, password);
statement = connection.prepareStatement(sql);
statement.setString(1, movie.getTitle());
resultSet = statement.executeQuery();
while(resultSet.next())
{
Star star = new Star();
star.setId(resultSet.getInt("id"));
star.setFirstName(resultSet.getString("first_name"));
star.setLastName(resultSet.getString("last_name"));
star.setDOB(resultSet.getString("dob"));
star.setPhoto(resultSet.getString("photo_url"));
result.add(star);
}
}
catch (SQLException e)
{
e.printStackTrace();
}
finally
{
if (resultSet != null) try { resultSet.close(); } catch (SQLException ignore) {}
if (statement != null) try { statement.close(); } catch (SQLException ignore) {}
if (connection != null) try { connection.close(); } catch (SQLException ignore) {}
}
}
return result;
}
}
'
public class MovieListServlet extends HttpServlet
{
List<Movie> movieItems;
List<Star> starList;
String query;
Movie movie;
@Override
public void init(ServletConfig config) throws ServletException
{
query = null;
movie = null;
ServletContext context = config.getServletContext();
context.getRequestDispatcher("/jsp/movielist.jsp");
}
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException
{
try
{
movieItems = (List<Movie>) req.getAttribute("movies");
req.getSession().setAttribute("movies", movieItems);
starList = (List<Star>) req.getAttribute("starlist");
req.getSession().setAttribute("stars", starList);
req.getRequestDispatcher("/jsp/movielist.jsp").forward(req, resp);
}
catch(Exception e)
{
System.out.println(e);
}
/**
try
{
movieItems = new MovieDAO().movieList();
}
catch (Exception e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
req.getSession().setAttribute("movies", movieItems);
req.getRequestDispatcher("/jsp/movielist.jsp").forward(req, resp);
*/
}
}
'
'
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt" %>
<table>
<a href="home">Home</a>
<c:forEach var="star" items="${stars}">
<tr>
<td>${star.id}</td>
<td>${star.first_name}</td>
<td>${star.last_name}</td>
<td>${star.dob}</td>
<td>${star.photo_url}</td>
</tr>
</c:forEach>
<c:forEach var="movie" items="${movies}">
<tr>
<td>${movie.id}</td>
<td><a href="movies?query=${movie.id}"> ${movie.title}</td>
<td>${movie.year}</td>
<td>${movie.director}</td>
<td> <img src ="${movie.banner}"></td>
<td><a href="${movie.trailer}">trailer</a></td>
</tr>
</c:forEach>
</table>
'
最佳答案
经过一番思考,我决定从另一个方向着手,创建一个包含先前类的两个私有(private)字段的类。通过使用单个类,我可以进行单个 SQL 查询,而不是两个单独的查询。它没有解决我之前的问题,但它有效。
关于java - 发送两个不同类的对象到jsp并显示信息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35248608/
是否可以让标准 Java EE servlet 容器将文件解释并呈现为 JSP,即使该文件没有 .jsp 扩展名? 假设我的 WAR 根目录中有一个名为 foo.xyz 的文件。该文件包含一些 jST
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 6年前关闭。 Improve thi
我有几个通用元素(组件),它们会生成一些 html。似乎我的选择是创建一个 taglib,或者只是将该逻辑放入一个 jsp 页面并包含 jsp。 有什么不同?积极与消极? 最佳答案 Taglibs 允
我是 Ejb-JSP 的新手,对它知之甚少。我已经创建了一个 JSP 页面,它调用 Controller Servlet,而 servlet 调用 EJB。结构就像 JSP -> Servlet ->
我想编写一个自定义 JSP 标签,其输出包括其他 JSP 标签,这些标签本身也应该被动态评估。但显然我的一切TagSupport子类写入 pageContext.getOut()无需任何进一步评估,直
我有一个包含页面顶部内容的 JSP,我们称它为 header.jsp。出于性能原因,我想呈现此 JSP 并将其刷新给用户,然后再构建页面的其余部分。 (有关性能优势的解释,请参阅 here。) 我能想
我发现自己在处理一些旧的 JSP,想做一些简单的事情,比如以 dd/mm/yyyy 格式显示今天的日期 好像没那么简单, 到目前为止,我已经导入了 java.util.* 我试过很多东西 String
关于 JSP 标签字符集的简单问题。 mytag很简单。 tag文件位于 WEB-INF/tags .这个文件在 Eclipse 中的字符集是 UTF-8。出于某种原因,UTF-8 符号无法
这让我很吃惊!我的 JSP 中有以下代码。 在我重构 SlideShow 类并公开所有属性并删除 getter/setter 之前,这段代码一直有效。所以在我看来,EL 只适用于 getter 而不
现有的一组 JSP,用英文字段标签、javascript 错误/信息消息、图像“alt”消息等硬编码,需要多语言化。 将这些 JSP 转换为使用标准 Java 多语言功能(资源包、语言环境等)的最佳方
Closed. This question needs to be more focused。它当前不接受答案。 想改善这个问题吗?更新问题,使其仅通过editing this post专注于一个问题
我已经在 Tomcat 6.0 下部署了我们的 War 到 Linux 服务器。在那个 Linux 机器上,我们没有打开浏览器的权限。 是否可以从命令行执行 JSP? 最佳答案 您可以使用其中 wge
有没有人建议为 JSP 设置最佳缓冲区大小?您可以使用以下页面指令在 JSP 中设置缓冲区大小 我的问题如下 我的理解是,您使用的缓冲区大小越小,客户端浏览器的性能就越好。我的假设正确吗?如
我们正在使用 JBoss 7.1.3.Final 和 Java 6。我想将 UTF-8 页面编码应用于我们网站上提供的所有 JSP 页面,因此我将其添加到我们的 web.xml 文件中
学过jsp native,想包含动态文件。我想使用 include 调用动态页面 这段代码 如果我输入 dashboard.jsp?p=about 页面打开“pages/a
在我的 JSP 页面中,我希望链接转发到另一个 JSP 页面。当用户在 home.jsp 上时,我希望他们转到 login.jsp 等。我遇到的问题是无法找到 JSP,除非我将页面放在项目文件夹中(在
我正在尝试在新的grails应用程序中使用index.jsp切换index.gsp。我将默认的index.gsp重命名为not_index.gsp,并添加了index.jsp。现在,我收到以下错误。
是否可以从服务器端 jsf 代码将资源打开到新的浏览器选项卡(如命令按钮的 target="_newtab")? 以下代码在同一选项卡中打开资源: FacesContext.getCurrentIns
我想问一个关于 .jsp 的问题。使用 jsp 语法(例如 )和 XML 语法(例如 ... )有什么不同。使用其中一种语法是否有维护或某种 advs?谢谢。 最佳答案 原始的 语法更加紧凑,但如
JSP 文件是否有行业标准命名约定? 我遇到过来自不同来源的三种约定: 全部小写 (thisismyfile.jsp) 首字母小写的驼峰式大小写 (thisIsMyFile.jsp) 首字母大写的驼峰
我是一名优秀的程序员,十分优秀!