JavaWeb 第7章 JQuery 的 Ajax 交互扩展 任务1:掌握更多 jQuery 实现 Ajax 的方法

 JavaWeb 应用设计及实战 目录

上一章   下一章

上一个任务/上一节       下一个任务/下一节

目录

任务1:掌握更多 jQuery 实现 Ajax 的方法

    7.1.7   $.get() 方法和$.post() 方法

       1. $.get() 方法

                      表 7-1 $.get() 方法的常用参数

                                       示例 1 

        2.$.post() 方法

                                      示例2

技能训练

上机练习 1 —— 使用 $.get() 和 $.post() 方法实现异步验证注册邮箱

7.1.2   $.getJSON()方法

                       表 7-3 $.getJSON()方法的常用参数

                                     示例 3 

技能训练

上机练习2 ——使用 $.getJSON() 方法加载管理员页面主题列表


任务1:掌握更多 jQuery 实现 Ajax 的方法

       前面章节中介绍了如何使用原生 JavaScript 实现 Ajax 技术来提升用户体验。由于

通过原生 JavaScript 实现 Ajax 并处理响应相对比较复杂,还要考虑浏览器兼容性等一

系列问题, jQuery 中将 Ajax 相关的操作进行了封装,提供了 $.ajax() 方法以简化 Ajax

开发。

        除了 #ajax() 方法以外,jQuery 还提供了几种简单的 Ajax 实现方法,如$.get()、

$.post()、#.getJSON()、对象.load() 等方法,下面介绍它们的具体用法。

    7.1.7   $.get() 方法和$.post() 方法

       1. $.get() 方法

      $.(get)方法时 jQuery 封装的发送 HTTP GET 请求并从服务器加载数据的 Ajax 方法。

具体语法如下。

       语法

$.get(url[,data][,success][,dataType]);

        该方法的详细参数说明如表 7-1 所示。

表 7-1 $.get() 方法的常用参数

参数 类型 说明 url String

必选,规定将请求发送到哪个 URL

data PlainObject 或 String 可选,规定连同请求发送到服务器的数据 success

Function(PlainObjet data,

String textStatus,jqXHR jqxhr)

可选,请求成功后调用的函数

参数 data :可选,表示服务器返回的结果数据

参数 textStatus:可选,描述请求状态的字符串

参数 jqxhr:可选,jqXHR 是 XMLHttpRequest的超集

如果指定了 dataType,则必须提供此参数,如果没有任务需要处

理,可以使用 null 或 jQuery.noop() 空方法作为占位符

dataType String

可选,预期服务器返回的数据类型,可用类型有 XML、HTML、

SCRIPT、JSON、JSONP、Text

     了解了 $.get() 方法的常用参数,接下来就一实现用户名验证功能为例,对比

$.ajax() 方法,使用 $.geet() 方法实现 Ajax 异步验证用户名,如示例 1 所示。

    示例 1 

$(document).ready(function()){
    $("#name").blur(func
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的JavaWeb项目的MVC模式进行后端管理员RSA加密登录的具体代码实现。这个示例使用MySQL数据库,利用layUI框架和ajax接口请求。 1. Model 创建一个JavaBean类,用于存储管理员信息。 ``` public class Admin { private int id; private String username; private String password; private String publicKey; private String privateKey; // 省略getter和setter方法 } ``` 2. Controller 创建一个Servlet类,用于处理管理员登录请求。 ``` public class AdminLoginController extends HttpServlet { protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 获取用户名和密码 String username = request.getParameter("username"); String password = request.getParameter("password"); // 从数据库中获取管理员信息 AdminDao adminDao = new AdminDao(); Admin admin = adminDao.getAdminByUsername(username); // 如果没有找到该管理员,返回错误信息 if (admin == null) { response.getWriter().write("error"); return; } // 生成RSA公私钥对 RSA rsa = new RSA(); admin.setPublicKey(rsa.getPublicKeyBase64()); admin.setPrivateKey(rsa.getPrivateKeyBase64()); // 保存公私钥对到数据库 adminDao.updateAdmin(admin); // 使用RSA加密密码 String encryptedPassword = rsa.encryptBase64(password); // 比较加密后的密码和数据库中的密码 if (!encryptedPassword.equals(admin.getPassword())) { response.getWriter().write("error"); return; } // 登录成功,保存管理员信息到session中 HttpSession session = request.getSession(); session.setAttribute("admin", admin); // 返回成功信息 response.getWriter().write("success"); } } ``` 3. View 使用layUI框架创建登录页面。 ``` <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>管理员登录</title> <link rel="stylesheet" href="https://cdn.staticfile.org/layui/2.5.6/css/layui.min.css"> </head> <body> <div class="layui-container"> <div class="layui-row"> <div class="layui-col-md6 layui-col-md-offset3"> <form class="layui-form" action=""> <div class="layui-form-item"> <label class="layui-form-label">用户名</label> <div class="layui-input-block"> <input type="text" name="username" required lay-verify="required" placeholder="请输入用户名" autocomplete="off" class="layui-input"> </div> </div> <div class="layui-form-item"> <label class="layui-form-label">密码</label> <div class="layui-input-block"> <input type="password" name="password" required lay-verify="required" placeholder="请输入密码" autocomplete="off" class="layui-input"> </div> </div> <div class="layui-form-item"> <div class="layui-input-block"> <button class="layui-btn" lay-submit lay-filter="login">登录</button> </div> </div> </form> </div> </div> </div> <script src="https://cdn.staticfile.org/jquery/3.5.1/jquery.min.js"></script> <script src="https://cdn.staticfile.org/layui/2.5.6/layui.min.js"></script> <script> layui.use(['form', 'layer'], function(){ var form = layui.form; var layer = layui.layer; // 监听登录表单提交 form.on('submit(login)', function(data){ // 发送ajax请求 $.ajax({ url: 'AdminLoginController', type: 'POST', data: data.field, success: function(result) { // 登录成功,跳转到管理页面 if (result == 'success') { window.location.href = 'admin.jsp'; } else { // 登录失败,显示错误信息 layer.msg('用户名或密码错误', {icon: 5}); } }, error: function() { layer.msg('登录失败,请重试', {icon: 5}); } }); return false; }); }); </script> </body> </html> ``` 4. DAO 创建一个DAO类,用于与数据库交互。 ``` public class AdminDao { // 数据库连接信息 private String jdbcUrl = "jdbc:mysql://localhost:3306/javaweb"; private String jdbcUsername = "root"; private String jdbcPassword = "root"; // 获取管理员信息 public Admin getAdminByUsername(String username) { String sql = "SELECT * FROM admin WHERE username = ?"; try (Connection conn = DriverManager.getConnection(jdbcUrl, jdbcUsername, jdbcPassword); PreparedStatement stmt = conn.prepareStatement(sql)) { stmt.setString(1, username); try (ResultSet rs = stmt.executeQuery()) { if (rs.next()) { Admin admin = new Admin(); admin.setId(rs.getInt("id")); admin.setUsername(rs.getString("username")); admin.setPassword(rs.getString("password")); admin.setPublicKey(rs.getString("public_key")); admin.setPrivateKey(rs.getString("private_key")); return admin; } } } catch (SQLException ex) { ex.printStackTrace(); } return null; } // 更新管理员信息 public void updateAdmin(Admin admin) { String sql = "UPDATE admin SET public_key = ?, private_key = ?, password = ? WHERE id = ?"; try (Connection conn = DriverManager.getConnection(jdbcUrl, jdbcUsername, jdbcPassword); PreparedStatement stmt = conn.prepareStatement(sql)) { stmt.setString(1, admin.getPublicKey()); stmt.setString(2, admin.getPrivateKey()); stmt.setString(3, admin.getPassword()); stmt.setInt(4, admin.getId()); stmt.executeUpdate(); } catch (SQLException ex) { ex.printStackTrace(); } } } ``` 注意:为了保证安全性,RSA公私钥对应该定时更新,这里没有实现定时更新的代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值