広範囲に渡ってSQL注入保護(ExploitProtectionServiceImpl)を提供していますが、私はProductDaoを使用することをお勧めします。
- org.broadleafcommerce.core.web.api.endpoint.catalog.CatalogEndpointを拡張するか、それはしてデータベースを照会していますProductDao
@Resource("blProductDao")
private ProductDao productDao;
@RequestMapping(value = "search/products-by-category/{categoryId}") //GET is by default
public List<Product> findSearchResultsByCategory(HttpServletRequest request, @PathVariable("categoryId") Long categoryId {
return productDao.readProductsByCategory(categoryId);
}
SELECT categoryProduct.product_id
FROM BLC_CATEGORY_PRODUCT_XREF categoryProduct
WHERE categoryProduct.category_id = :categoryId
ORDER BY COALESCE (categoryProduct.display_order,999999)
public class MyProductDaoImpl extends ProductDaoImpl implements MyProductDao {
public static final String QUERY = "SELECT categoryProduct.product_id " +
"FROM BLC_CATEGORY_PRODUCT_XREF categoryProduct " +
"WHERE categoryProduct.category_id = :categoryId";
@Override
public List<Product> meFindingProductsByCategory(String categoryId) {
Query query = em.createQuery(QUERY);
query.setParameter("categoryId", categoryId);
return query.getResultList();
}
}
- を作成したい場合は、JSONまたはXMLを生産している場合は、選択することができます。バインディング結果に対応する製品モデルがあることを確認してください。