第一:下面的img.jspx是我Action的一个方法
<img src="img.jspx" width="60" height="20" align="bottom" style="cursor:hand" onClick="refIm(this);">
第二:下面代码用于生成验证码。
public void initImg(HttpServletRequest req, HttpServletResponse res,
ModelMap model) throws Exception {
logger.info("刷新验证码!");
res.setContentType("image/jpeg");
res.setHeader("Pragma", "No-cache");
res.setHeader("Cache-Control", "no-cache");
res.setDateHeader("Expires", 0);
HttpSession session = req.getSession();
int width = 60, height = 20;
BufferedImage image = new BufferedImage(width, height,
BufferedImage.TYPE_INT_RGB);
// 获取图形上下文
Graphics g = image.getGraphics();
// 生成随机类
Random random = new Random();
// 设定背景色
g.setColor(getRandColor(200, 250));
g.fillRect(0, 0, width, height);
// 设定字体
g.setFont(new Font("Times New Roman", Font.PLAIN, 18));
// 画边框
// g.setColor(new Color());
// g.drawRect(0,0,width-1,height-1);
// 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到
g.setColor(getRandColor(160, 200));
for (int i = 0; i < 155; i++) {
int x = random.nextInt(width);
int y = random.nextInt(height);
int xl = random.nextInt(12);
int yl = random.nextInt(12);
g.drawLine(x, y, x + xl, y + yl);
} // 取随机产生的认证码(4位数字)
String sRand = "";
for (int i = 0; i < 4; i++) {
String rand = String.valueOf(random.nextInt(10));
sRand += rand;
// 将认证码显示到图象中
g.setColor(new Color(20 + random.nextInt(110), 20 + random
.nextInt(110), 20 + random.nextInt(110)));// 调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成
g.drawString(rand, 13 * i + 6, 16);
}
// 将认证码存入SESSION
session.setAttribute("rand", sRand);
// 图象生效
g.dispose();
// 输出图象到页面
ImageIO.write(image, "JPEG", res.getOutputStream());
}第三:以上都没有问题
问题是我单击验证码的时候不刷新(能执行下面的javaScript,但是不能请求道服务器)
//刷新验证码
function refImg(obj){
obj.src="img.jspx";

}                       

解决方案 »

  1.   

    obj.src="img.jspx"; 这样可以向服务器发送请求吗?
      

  2.   


    obj.src="img.jspx?Date="+new Date().getTime();
      

  3.   

    不是标识的问题,是刷新obj.src=“img.jspx”的时候根本就不往服务器提交。
    刷新整个页面的时候可以提交。
      

  4.   

    不是吧,楼主代码有个小问题啊。不知道是发帖的时候写错了还是一直都是些错了。onclick里的函数调用应该是 refImg 啊。如果本身没错的话,搂着可以试试在 img 标签外嵌套一个 div 并指定 id 属性。然后将
    refImg改成下面的function refImg(){
       document.getElementById("id").innerHTML=<img src="img.jspx" width="60"
       height="20" align="bottom" style="cursor:hand" onClick="refImg();"> 
    }id 就是外面嵌套的 div 的 id 属性
      

  5.   

    是发帖的时候写错了,能够调用javaScript代码但是不提交,如果把obj.src改成一个图片的路径是可以改变的。
      

  6.   

    function refImg(obj){
    obj.src="img.jspx";} 页面图片缓存问题,请求地址后加个随机数就可以了