【发布时间】:2016-03-23 04:43:12
【问题描述】:
我正在尝试在我的轮播页面的 jsp 页面中显示来自 servlet 的多个图像,但只显示第一个图像。我想知道如何显示 Sql 查询的所有结果。servlet 代码是
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
//response.setContentType("image/jpg");
HttpSession myses = request.getSession(true);
String imageid = request.getParameter("id");
//System.out.println("In servlet"+imageid);
ServletOutputStream o;
try {
Class.forName(driverName);
con = DriverManager.getConnection(url,userName,password);
String sql = "select mid from carousel_two where cid= '"+imageid+"'";
PreparedStatement stmt = con.prepareStatement(sql);
ResultSet rs = stmt.executeQuery();
myses.setAttribute("lis",rs);
byte[] obj = new byte[1434295];
byte[] sample = null;
int srcPos = 0;
//int i=0;
//String encoded =new String ();
o = response.getOutputStream();
java.util.List<String> strings = new ArrayList<String>();
//StringJoiner joiner = new StringJoiner(",");
if(rs!=null ) {
while(rs.next()) {
String sql1 = "select img from carousel_two where mid= '"+rs.getInt("mid")+"'";
PreparedStatement stmt1 = con.prepareStatement(sql1);
ResultSet rs1 = stmt1.executeQuery();
if(rs1!=null) {
while(rs1.next()){
//int id = rs.getInt(1);
//System.out.println("id = "+id);
sample = rs1.getBytes("img");
int length = sample.length;
System.arraycopy(sample, 0, obj,srcPos, length);
srcPos += length;
//System.out.println("Length required = " + srcPos);
//if(rs!=null) {
//System.out.println("mid"+rs.getInt("mid"));
//o.write(rs.getBytes("img"));
byte[] newArray = new byte[srcPos];
System.arraycopy(obj, 0, newArray, 0, srcPos);
response.setContentType("image/jpg");
// response.getOutputStream().write(newArray);
strings.add(DatatypeConverter.printBase64Binary(newArray));
//System.out.println(strings+"\n");
// encoded=DatatypeConverter.printBase64Binary(newArray);
}
}
//}
}
}
//int x=(encoded.split(";")).length;
// System.out.println("X"+x);
//encoded=String.join(",", strings1);
//encoded= String.join(",", strings);
String json = new Gson().toJson(strings);
response.setContentType("application/json");
response.setCharacterEncoding("UTF-8");
o.print(json);
o.flush();
}catch (Exception e) {
e.printStackTrace();
}
}
而javascript代码是
function trigger(idx, state) {
document.getElementById('touchScroller').innerHTML=" ";
$.ajax({
type : "GET",
url : "Sampleimage1",
contentType :"application/json",
data:{id:idx},
success : function(data) {
var da=data;
//da=data.split(",");
//alert(typeof data);
//alert(da.length);
$.each(da,function(index,item){
alert( index);
$('#touchScroller').append('<img src="data:image/jpg;base64,' +item +'" />');
});
}
});
}
我是这方面的新手,因此我们将不胜感激。
【问题讨论】:
标签: javascript java jsp servlets