<%@ page contentType="text/html; charset=utf-8" language="java" import="java.sql.*" errorPage=""%> <%@ page import="com.dao.BookDAO"%> <%@ page import="com.dao.BookTypeDAO"%> <%@ page import="com.actionForm.BookForm"%> <%@ page import="com.actionForm.BookTypeForm"%> <%@ page import="com.dao.BookCaseDAO"%> <%@ page import="com.actionForm.BookCaseForm"%> <%@ page import="com.dao.PublishingDAO"%> <%@ page import="com.actionForm.PublishingForm"%> <%@ page import="java.util.*"%> <html> <% String str = null; BookTypeDAO bookTypeDAO = new BookTypeDAO(); Collection coll_type = (Collection) bookTypeDAO.query(str); if (coll_type == null || coll_type.isEmpty()) { out.println("<script>alert('请先录入图书类型信息!');history.back(-1);</script>"); } else { Iterator it_type = coll_type.iterator(); int typeID = 0; String typename = ""; BookCaseDAO bookcaseDAO = new BookCaseDAO(); String str1 = null; Collection coll_bookcase = (Collection) bookcaseDAO.query(str1); if (coll_bookcase == null || coll_bookcase.isEmpty()) { out.println("<script>alert('请先录入书架信息!');history.back(-1);</script>"); } else { Iterator it_bookcase = coll_bookcase.iterator(); int bookcaseID = 0; String bookcasename = ""; PublishingDAO pubDAO = new PublishingDAO(); String str2 = null; Collection coll_pub = (Collection) pubDAO.query(str2); if (coll_pub == null || coll_pub.isEmpty()) { out.println("<script>alert('请先录入出版社信息!');history.back(-1);</script>"); } else { Iterator it_pub = coll_pub.iterator(); String isbn = ""; String pubname = ""; %> <script language="jscript"> function check(form){ if(form.barcode.value==""){ alert("请输入条形码!");form.barcode.focus();return false; } if(form.bookName.value==""){ alert("请输入图书名称!");form.bookName.focus();return false; } if(form.price.value==""){ alert("请输入图书定价!");form.price.focus();return false; } } </script>

时间: 2023-06-25 12:05:36 浏览: 56
这段代码是一个 JSP 页面,用于添加图书信息。在页面中,首先通过 BookTypeDAO、BookCaseDAO 和 PublishingDAO 查询图书类型、书架和出版社信息。如果这些信息为空,会通过 JavaScript 弹窗提示用户先录入相关信息。如果这些信息都不为空,则会显示一个表单,让用户输入图书的条形码、名称、价格等信息,并通过 JavaScript 验证用户输入的合法性。在用户点击提交按钮后,会将表单数据传递给 BookDAO,通过 BookDAO 将图书信息插入到数据库中。
相关问题

讲解<%@ page contentType="text/html; charset=utf-8" language="java" import="java.sql." errorPage=""%> <%@ page import="com.dao.BookDAO"%> <%@ page import="com.actionForm.BookForm"%> <%@ page import="java.util."%> <html> <% Collection coll = (Collection) req

uest.getAttribute("allBooks"); %> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>图书列表</title> </head> <body> <h2>图书列表</h2> <table border="1" cellspacing="0" cellpadding="0"> <tr> <td>编号</td> <td>书名</td> <td>作者</td> <td>出版社</td> </tr> <% for (Iterator it = coll.iterator(); it.hasNext();) { BookForm book = (BookForm) it.next(); %> <tr> <td><%=book.getId()%></td> <td><%=book.getName()%></td> <td><%=book.getAuthor()%></td> <td><%=book.getPublisher()%></td> </tr> <% } %> </table> </body> </html> 这是一个 JSP 页面,用于显示图书列表。其中,通过 BookDAO 类获取所有图书的信息,存储在一个 Collection 对象中,并将其设置为 request 对象的属性,以便在 JSP 页面中使用。接着,通过迭代器遍历 Collection 对象,将每个图书的编号、书名、作者和出版社显示在表格中。 需要注意的是,为了避免中文乱码问题,使用了 UTF-8 编码方式。同时,引入了 BookForm 和 BookDAO 类,以及 java.util 包。

插入"152@qq.com"出错

如果插入 "152@qq.com" 出错,可能是因为在获取表单中输入框的值时,没有正确处理特殊字符 "@"。在JSP中,可以使用 EL 表达式的方式获取表单中输入框的值,例如: ```jsp <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ page import="java.sql.*" %> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Insert Data</title> </head> <body> <h1>Insert Data</h1> <form action="insert.jsp" method="post"> <label for="phone">Phone:</label> <input type="text" name="phone" id="phone"> <br/><br/> <input type="submit" value="Insert"> </form> <% if(request.getMethod().equals("POST")){ String phone = request.getParameter("phone"); if(phone != null && !phone.equals("")) { try { // 导入JDBC驱动程序并建立数据库连接 Class.forName("com.mysql.jdbc.Driver"); Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "password"); // 编写SQL语句并创建PreparedStatement对象 String sql = "INSERT INTO your_table (phone) VALUES (?)"; PreparedStatement pstmt = conn.prepareStatement(sql); // 设置参数值 pstmt.setString(1, "${param.phone}"); // 执行SQL语句并提交事务 pstmt.executeUpdate(); conn.commit(); // 关闭连接 pstmt.close(); conn.close(); out.println("Data inserted successfully!"); } catch (Exception e) { e.printStackTrace(); out.println("Error: " + e.getMessage()); } } else { out.println("Phone number cannot be empty!"); } } %> </body> </html> ``` 请注意,这里使用 `${param.phone}` 获取输入框的值,这样可以避免特殊字符的问题。另外,为了避免SQL注入攻击,建议使用参数化查询。

相关推荐

最新推荐

recommend-type

微信小程序-番茄时钟源码

微信小程序番茄时钟的源码,支持进一步的修改。番茄钟,指的是把工作任务分解成半小时左右,集中精力工作25分钟后休息5分钟,如此视作种一个“番茄”,而“番茄工作法”的流程能使下一个30分钟更有动力。
recommend-type

激光雷达专题研究:迈向高阶智能化关键,前瞻布局把握行业脉搏.pdf

电子元件 电子行业 行业分析 数据分析 数据报告 行业报告
recommend-type

安享智慧理财测试项目Mock服务代码

安享智慧理财测试项目Mock服务代码
recommend-type

课程设计 基于SparkMLlib的ALS算法的电影推荐系统源码+详细文档+全部数据齐全.zip

【资源说明】 课程设计 基于SparkMLlib的ALS算法的电影推荐系统源码+详细文档+全部数据齐全.zip课程设计 基于SparkMLlib的ALS算法的电影推荐系统源码+详细文档+全部数据齐全.zip 【备注】 1、该项目是高分毕业设计项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(如软件工程、计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载使用,也可作为毕业设计、课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!
recommend-type

华中科技大学电信专业 课程资料 作业 代码 实验报告-雷达与信息对抗-内含源码和说明书.zip

华中科技大学电信专业 课程资料 作业 代码 实验报告-雷达与信息对抗-内含源码和说明书.zip
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用 Python 画一个可以动的爱心

好的,我可以帮助您使用Python来绘制一个动态的爱心。您可以使用turtle库来实现。以下是实现代码: ```python import turtle import math # 设置画布和画笔 canvas = turtle.Screen() canvas.bgcolor("black") pencil = turtle.Turtle() pencil.speed(0) pencil.color("red", "pink") pencil.pensize(3) # 定义爱心函数 def draw_love(heart_size, x_offset=0, y_offset=0):
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。