Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/354.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 标记没有显示在JSP中,也不起作用_Java_Html_Jsp_Servlets - Fatal编程技术网

Java 标记没有显示在JSP中,也不起作用

Java 标记没有显示在JSP中,也不起作用,java,html,jsp,servlets,Java,Html,Jsp,Servlets,不知何故,标签根本不起作用。它不显示任何警报,只是空白。就像我从来没有把标签添加到文件中一样。这是我的密码: Connector.java: package connect; import java.io.IOException; import java.io.PrintWriter; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQ

不知何故,标签根本不起作用。它不显示任何警报,只是空白。就像我从来没有把标签添加到文件中一样。这是我的密码:

Connector.java:

package connect;

import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;

import javax.servlet.ServletContext;
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 javax.servlet.http.HttpSession;

import products.Product;

/**
 * Servlet implementation class Connector
 */
@WebServlet("/Connector")
public class Connector extends HttpServlet {
    private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public Connector() {
        super();
        // TODO Auto-generated constructor stub
    }

    /**
     * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
     */
    @SuppressWarnings({ "unchecked", "null", "unused" })
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        PrintWriter out = response.getWriter();  
        try {
            Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");  
            String url = "jdbc:sqlserver://\\\\.\\pipe\\MSSQL$SQLEXPRESS\\sql\\query:8888;databaseName=ShoppingDB";
            Connection con = DriverManager.getConnection(url,"sa","33887899");
            Statement stmt = con.createStatement();  
            ArrayList<Product> pro=new ArrayList<Product>();
            ResultSet rs=stmt.executeQuery("select * from Products");
            Product p = new Product();
            while(rs.next()) {
                p.setId(rs.getInt("product_id"));
                p.setName(rs.getString("product_name"));
                p.setDes(rs.getString("product_des"));
                p.setPrice(rs.getInt("product_price"));
                p.setSrc(rs.getString("product_img_source"));
                p.setType(rs.getString("product_type"));
                p.setBrand(rs.getString("product_brand"));
                p.setAmount(1000);
                pro.add(p);
            }
            Product re;
            String name=request.getParameter("search");
            for(int i =0;i<pro.size();i++) {
                if(pro.get(i).getName()==name) {
                    re=pro.get(i);
                    break;
                }
            }
            p=pro.get(0);
            ServletContext context=getServletContext();
            context.setAttribute("p", p);
        }catch(Exception e) {
            out.println(e);
        }
        
    }
    
    /**
     * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
        doGet(request, response);
    }

}
Home.jsp

<%@ page language="java" contentType="text/html; charset=ISO-8859-1" pageEncoding="ISO-8859-1"%>
<!DOCTYPE html>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>  
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
<html>
<head>
<meta charset="ISO-8859-1">
<title>Insert title here</title>
<link rel="stylesheet" href="Style.css">
</head>
<body style="background-color:#f5f5f5;">
    <h1 style="text-align:center">PRJ321X_202x</h1>
    <div id="nav">
        <button class="navbtn">Home</button>
        <button class="navbtn">Products</button>
        <button class="navbtn">About Us</button>
        <button class="navbtn" style="float:right;" onclick="location.href='Login.jsp'">Log in</button>
        <form style="float:right;" method="Post" action="Connector">
            <input name="search" id="search" type="text" placeholder="Search..">
            <input type="submit" style="display:none">
        </form>
        
    </div>
    <script src="Script.js"></script>
<div style="float:left;width:75%;margin-right:5px;" id="products">
    <div>
        <c:out value="${p.id}"/>
    </div>
</div>
<div style="float:left;width:24%">
    <div style="background-color:white;width:100%">
        <h3>Shopping cart</h3>
        <div style="height:2.5cm;background-color:#8f8d8d;width:100%">Your cart is currently empty</div>
    </div>
    <div style="background-color:white;width:100%">
        <h4>Popular products or banner</h4>
        <p>Iphone 11 Pro Max</p>
        <img src="11PM.jpg" style="width:50%">
        <p>Iphone 12 Pro Max</p>
        <img src="12PM.jpg" style="width:50%">
        <p>Samsung Galaxy S20</p>
        <img src="S20.jpg" style="width:50%">
    </div>
</div>

</body>
</html>

在servlet中,您正在执行

context.setAttribute("p", p);
但在JSP中,您正在执行以下操作:

<c:out value="${s.id}"/>
如果Home.jsp文件位于其他路径上,请相应地进行上述更改

Home.jsp:

<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>  
<c:out value="${p.id}" />
您正在重新使用产品;参考搜索你的产品,但你从来没有使用它,因为你做了一个p=pro.get0;要从列表中获取第一个产品,请使用p将其放置在JSP的上下文中。我想你是想用re来代替

不要将字符串与==进行比较。此代码:

if (pro.get(i).getName() == name) {
大概应该是这样的:

if (pro.get(i).getName().equalsIgnoreCase(name)) {
更重要的是,您需要确保保护自己不受NullPointerException的影响,以防getName也可以返回null。如果使用WHERE SQL子句,则无需再次循环并搜索产品


最后,您应该阅读一些关于您正在使用的概念和代码的书籍或文档。您可能最终能够在不完全了解发生了什么的情况下将某些内容组合在一起,但它可能不一定是您所期望的。

我尝试过这样做,但都不起作用。我仔细查看了您的代码,发现您没有使用JSP。见我的更新上面。我还注意到了一些其他问题,所以我将编辑我的答案,添加一些提示。谢谢,它成功了,我欠你我的大学证书,欢迎你。但别再投票给我所有的答案了。你可以因为这样做而让你的账户被冻结……你认为一个这样的账户比大学证书更重要吗?此外,这只是一个克隆,所以。。。但我会停下来的,所以别担心
while (rs.next()) {
    Product p = new Product();
    p.setId(rs.getInt("product_id"));
    // all the other props
    pro.add(p);
}
if (pro.get(i).getName() == name) {
if (pro.get(i).getName().equalsIgnoreCase(name)) {