Java 未捕获的SoapFault异常:[soapenv:服务器]在结果集开始之前

Java 未捕获的SoapFault异常:[soapenv:服务器]在结果集开始之前,java,php,soap,resultset,soap-client,Java,Php,Soap,Resultset,Soap Client,我正在为电子商务网站开发一个web服务,我正在将基于某个供应商id的所有产品从java返回到php客户端,但它给了我这个错误 Fatal error: Uncaught SoapFault exception: [soapenv:Server] Before start of result set in C:\wamp\www\eshop\viewProductsSupplier.php:194 Stack trace: #0 C:\wamp\www\eshop\viewProductsSupp

我正在为电子商务网站开发一个web服务,我正在将基于某个供应商id的所有产品从java返回到php客户端,但它给了我这个错误

Fatal error: Uncaught SoapFault exception: [soapenv:Server] Before start of result set in C:\wamp\www\eshop\viewProductsSupplier.php:194 Stack trace: #0 C:\wamp\www\eshop\viewProductsSupplier.php(194): SoapClient->__soapCall('viewProducts', Array) #1 {main} thrown in C:\wamp\www\eshop\viewProductsSupplier.php on line 194
我曾尝试检查查询是否执行,但一切正常

//php代码

$soapclient = new SoapClient('http://localhost:8090/Eshop_ecommerce/services/Eshop_ecommerce?wsdl', ['trace' => 1]);
            session_start();
            $id=array('id'=>@$_SESSION['supplierId']);
            $response=$soapclient->__soapCall("viewProducts",$id);
            if (isset($response->Name))
            {
                print $response;
            }
            else
            {
                print "Data is null";
            }
//Java代码

ViewProductsResponse res = new ViewProductsResponse();
                Class.forName(driver);
                conn = DriverManager.getConnection(url,username,password);
                stmt = conn.createStatement();
                String Query=null;
                String in=viewProducts.getViewProductsRequest();
                if(!in.isEmpty())
                {
                    Query="SELECT * FROM product";
                }
                else
                {
                    Query="SELECT * FROM product WHERE product_supplier_id='"+viewProducts.getViewProductsRequest()+"'";
                }
                ProductArray pa=new ProductArray();
                ResultSet result= stmt.executeQuery(Query);
                //System.out.println(result);
                while(result.next())
                {
                    Product p= new Product();
                    //System.out.println(result.getString("product_id"));
                    p.setId(result.getString("product_id"));
                    p.setName(result.getString("product_name"));
                    p.setPrice(result.getString("product_price"));
                    p.setStock(result.getString("product_stock"));
                    String supplierNameQuery="SELECT supplier_id,supplier_name FROM supplier WHERE supplier_id='"+result.getString("product_supplier_id")+"'";
                    ResultSet resultSupplierName = stmt.executeQuery(supplierNameQuery);
                    p.setSupplierName(resultSupplierName.getString("supplier_name"));
                    String catQuery="SELECT * FROM product_category WHERE category_id='"+result.getString("product_category_id")+"'";
                    ResultSet resCat= stmt.executeQuery(catQuery);
                    p.setCategoryName(resCat.getString("category_name"));
                    pa.setProduct(p);
                    res.setProducts(pa);
                }
                //res.setViewProductsResponse("Data Entered");
                return res;
其中,正如我所期望的那样,它将打印所有生成的产品

返回的一个位于第一行之前(参见JavaDoc中的链接)。为了使此类
ResultSet
指向第一行,它需要重新定位到第一行,例如使用方法。这是为外部
选择而做的,但不为两个内部选择而做。此外,需要检查
next()
调用的返回值,以查看该
ResultSet
中是否有任何行

这可以通过如下方式实现:

 if(resultSupplierName.next()) {
     p.setSupplierName(resultSupplierName.getString("supplier_name"));
 }
 if(resCat.next()) {
     p.setCategoryName(resCat.getString("category_name"));
 }

请注意,发布的代码还有其他未解决的问题,例如JDBC资源没有关闭。我强烈建议您研究JEE或Spring(假定代码显然在应用服务器中运行),或者至少研究一下。此外,代码倾向于

感谢您的帮助。。。它是有效的。。。同时,我也将遵循关于JDBC的建议再次感谢!!!