跳转到登陆页的时候验证码页面不刷新是怎么回事?

原先验证码是这么写的:

<div class="lib">
            <span class="lib_l">验证码:</span><span class="lib_r"><asp:TextBox ID="verifyCode_txt"
                runat="server" Width="90px" CssClass="r_text r_text3" runat="server" MaxLength="4"></asp:TextBox><a
                    href="#"><img id="imgVerify" alt="看不清?点击更换" onclick="this.src=this.src+'?'" src="VerifyCode.aspx?"
                        style="vertical-align: bottom; width: 80px; height: 20px; border: 1px solid #ccc;" /></a></span></div>

之后点击“重新登录”,
Response.Write("<script>window.parent.location.href='LoginNew2.aspx'</script>");

但之后我断点到VerifyCode.aspx.cs是没有访问到的,请问下这是怎么回事??

 

论坛大牛给的解决方法:

一般都是IE缓存引起的

方案一:对页面进行不缓存处理
    protected void Page_Load(object sender, EventArgs e)
    {
        Response.Expires = 0;
        Response.CacheControl = "no-cache";
    }

方案二:<img标签用js输出
              <script type="text/javascript" language="JavaScript">
                   var numkey = Math.random();
                   numkey = Math.round(numkey*10000);
                   document.write("<img src=\"VerifyCode.aspx?k="+ numkey +"\" onClick=\"this.src+=Math.random()\" alt=\"图片看不清?点击重新得到验证码\" style=\"cursor:pointer;\" />");
                </script>

 

最有我用了第二种方法实现了,第一种方法依旧是失败的!!有待解决

<div class="lib">
            <span class="lib_l">验证码:</span><span class="lib_r"><asp:TextBox ID="verifyCode_txt"
                runat="server" Width="90px" CssClass="r_text r_text3" runat="server" MaxLength="4"></asp:TextBox><a
                    href="#">

                    <script type="text/javascript" language="JavaScript">
                    var numkey = Math.random();
                    numkey = Math.round(numkey*10000);
                    document.write("<img src=\"VerifyCode.aspx?k="+ numkey +"\" onClick=\"this.src+=Math.random()\" alt=\"图片看不清?点击重新得到验证码\" style=\"vertical-align: bottom; width: 80px; height: 20px; border: 1px solid #ccc;cursor:pointer;\" />");
                    </script>

                </a></span>
        </div>

 

转载于:https://www.cnblogs.com/wenghaowen/p/3581933.html

实现验证码登录页面,需要在之前的示例代码中添加一个验证码输入框和一个生成验证码的逻辑。 下面是一个使用 Java 和 Spring Boot 框架实现验证码登录页面的示例: 1. 在 `pom.xml` 文件中添加以下依赖: ```xml <dependency> <groupId>com.github.axet</groupId> <artifactId>kaptcha</artifactId> <version>2.3.2</version> </dependency> ``` 2. 创建一个 `LoginController` 类,该类包含以下方法: ```java @GetMapping("/login") public String login() { return "login"; } @PostMapping("/doLogin") public String doLogin(@RequestParam String username, @RequestParam String password, @RequestParam String verifyCode, HttpSession session) { String kaptchaCode = (String) session.getAttribute("kaptchaCode"); if (!verifyCode.equalsIgnoreCase(kaptchaCode)) { return "redirect:/login?error=验证码错误"; } // 验证用户名和密码,如果验证通过,则跳转到主 return "redirect:/index"; } @GetMapping("/verifyCode") public void verifyCode(HttpServletResponse response, HttpSession session) throws Exception { // 生成验证码图片,并将验证码文本存入 session response.setDateHeader("Expires", 0); response.setHeader("Cache-Control", "no-store, no-cache, must-revalidate"); response.addHeader("Cache-Control", "post-check=0, pre-check=0"); response.setHeader("Pragma", "no-cache"); response.setContentType("image/jpeg"); String verifyCode = new Kaptcha().createText(); session.setAttribute("kaptchaCode", verifyCode); BufferedImage image = new Kaptcha().createImage(verifyCode); ServletOutputStream out = response.getOutputStream(); ImageIO.write(image, "jpg", out); out.flush(); out.close(); } ``` 3. 创建一个 `login.html` 页面,包含以下代码: ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>验证码登录</title> <link rel="stylesheet" href="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/4.5.0/css/bootstrap.min.css"> </head> <body> <div class="container"> <div class="row justify-content-center"> <div class="col-md-6"> <div class="card"> <div class="card-header">验证码登录</div> <div class="card-body"> <form action="/doLogin" method="post"> <div class="form-group"> <label for="username">用户名</label> <input type="text" class="form-control" id="username" name="username" required autofocus> </div> <div class="form-group"> <label for="password">密码</label> <input type="password" class="form-control" id="password" name="password" required> </div> <div class="form-group"> <label for="verifyCode">验证码</label> <div class="input-group"> <input type="text" class="form-control" id="verifyCode" name="verifyCode" required> <img src="/verifyCode" onclick="this.src='/verifyCode?t='+Math.random()" style="cursor: pointer;"> </div> </div> <button type="submit" class="btn btn-primary btn-block">登录</button> </form> </div> </div> </div> </div> </div> </body> </html> ``` 在这个页面中,我们创建了一个包含用户名、密码和验证码输入框的表单,并使用 Bootstrap 样式美化页面验证码输入框旁边还有一个图像,点击图像可以刷新验证码。 这样,就实现了一个简单的验证码登录页面。当用户提交表单时,控制器会验证验证码是否正确,如果验证码正确,则继续验证用户名和密码,如果验证通过,则跳转到主。否则,将出现错误消息并重定向到登录页面
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值