JSP for query

时间:2022-05-02 20:15:25

1. JSP中部分常用标签

Form.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Form</title>
<script type="text/javascript">
function check(){
username = document.login.hehe.value;
console.log(username);
if(username.length<6 || username.length>8){
alert("用户名长度不合适!");
return false;
}else{
return true;
}
}
</script>
</head>
<body>
<form action="/login" name="login" method="post">
各种表单元素
Username:<input type="text" name="hehe" value="hehe">
Password:<input type="password" name="pwd" value="pwd">
</form>
<form>
Username:<input type="text" name="hehe" value="hehe">
Password:<input type="password" name="pwd" value="pwd">
<input type="submit" name="SUMBIT" value="SUMBIT">
<input type="reset" name="hehe" value="RESET">
<input type="button" value="button" onclick="javascript:check()">
</form>
<form>
<input type="radio" name="sex" value="1" checked>男
<input type="radio" name="sex" value="2">女
</form>
<br>
<form>
<input type="checkbox" name="hobby" value="1">Book
<input type="checkbox" name="hobby" value="2">Chess
<input type="checkbox" name="hobby" value="3">Movie
</form>
<select name="City">
<option value="1" selected>Tianjin</option>
<option value="2">Beijing</option>
<option value="3">Shanghai</option>
<option value="4">Xi'an</option>
<option value="5">Tangshan</option>
</select>
<form>
<textarea name="文本域" cols="10" rows="10">
默认文本
</textarea>
</form>
</body>
</html>

----------------------------------------------------------------------------------------------------------------

2. <jsp:forward>和response.sendRedirect()异同:

<%
String username = request.getParameter("username");
String userpass = request.getParameter("password");
if ("zhang".equals(username) && "123".equals(userpass)){
%>
<jsp:forward page="success.jsp"/>
<%
} else {
%>
<jsp:forward page="index.jsp"/>
<%
}
%>
<%
String username = request.getParameter("username");
String userpass = request.getParameter("password");
if ("zhang".equals(username) && "123".equals(userpass)){
response.sendRedirect("success.jsp");
} else {
response.sendRedirect("index.jsp");
}
%>

相同:均导向同一目标文件;

不同:1) <jsp:forward>属于一次请求,服务器端跳转,地址栏不发生变化; 而response.sendRedirect()导致二次请求,地址栏发生变化。

   2) 通过<jsp:forward>方式跳转到目标文件后,request中的对象仍起作用;而通过response.sendRedirect()跳转到目标文件后,request中的对象失效。

----------------------------------------------------------------------------------------------------------------

3. <jsp:include>标签

  效果同

<%@ include%>

但不同之处在于,include指令在编译期起作用,见目标文件预先加载进来;而<jsp:include>在运行期起作用,并且加载完后返回原文件继续执行。

----------------------------------------------------------------------------------------------------------------

4. <jsp:forward>和<jsp:include>的区别:

  <jsp:forward>在导向目标文件后,不再返回;<jsp:include>在导向目标文件后,会返回原文件继续执行后续代码。

----------------------------------------------------------------------------------------------------------------

5. 要想使用JSTL,需要以下两点的配置:

  1)

        <dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>taglibs</groupId>
<artifactId>standard</artifactId>
<version>1.1.2</version>
</dependency>

  2) 在JSP文件中声明标签库  

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>

----------------------------------------------------------------------------------------------------------------

6. 四大内置对象:application,session,request,pageContext的作用范围

application:所有用户所共享的存储位置;

session:每个用户对应一个session,用于存储本用户相关的信息;

request:每次访问会对应一个request,request是为每个用户的每次请求所设置的存储信息位置;

pageContext:pageContext对应每次访问的每个页面。

经常使用session和request。

若多次访问之间共享信息则使用session;若需要在某次访问的多个页面之间共享信息,则使用request(比如,使用jsp:forwrad转向的文件和当前文件就属于同一次请求)

==>由以上对session和request的理解,可知用户登录信息应保存在session中。

<c:set var="user" scope="session" value="hehe"/>

----------------------------------------------------------------------------------------------------------------

7. 对Servlet的个人理解:

1) 可以通过在JSP页面中嵌入Java代码来完成相应的逻辑控制等。但大量的Java代码和JSP元素混合造成难以维护,所以应该将Java代码同JSP页面分离开来。而分离的Java代码负责请求控制等,形成现在的Servlet。Servlet具有JSP类似的功能:1, 接受请求; 2, 调用方法; 3, 响应用户。但二者的专注点不同,JSP专注页面数据展示而Servlet专注请求逻辑控制。

2) 根据1)的分析可知,此时MVC模型中的V和C成型。

3) 在Java EE中,Servlet和JSP同属于其中的Web层组件。

4) 通常在应用服务器中,均对Servlet有基本的实现,而且基本为HttpServelt实现。比如,在Tomcat容器中,相应的包为javax.servlet.*和javax.servlet.http.*,存在于servlet-api.jar中。

5) 在定义并使用自己的Servlet时,需要以下必要步骤:

  1. extends HttpServlet

  2. 重写doGet/doPost方法

  3. 在web.xml中配置Servlet/使用注解@WebServlet

  4. 使用定义的Servlet

Example:

  1. extends HttpServlet  +  2. 重写doGet/doPost方法

public class LoginServlet extends HttpServlet {

    private static final Logger log = LoggerFactory.getLogger(LoginServlet.class);

    @Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
log.info("doGet implementation...");
req.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(req, resp);
log.info("doGet end");
} @Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
log.info("doPost implementation...");
String username = req.getParameter("username");
String password = req.getParameter("password");
UsernamePasswordToken token = new UsernamePasswordToken(username,password);
token.setRememberMe(true);
Subject subject = SecurityUtils.getSubject();
String error = null;
try {
subject.login(token);
} catch (UnknownAccountException e){
error = "Incorrect user/password";
} catch (IncorrectCredentialsException e){
error = "Incorrect user/password";
} catch (AuthenticationException e){
error = "other unknown error" + e.getMessage();
} log.error(error); if (error != null){
req.setAttribute("error",error);
req.getRequestDispatcher("/WEB-INF/jsp/login.jsp");
} else {
req.getRequestDispatcher("/WEB-INF/jsp/login_success.jsp");
}
log.info("doPost end");
}
}

  3. 在web.xml中配置Servlet/使用注解@WebServlet

@WebServlet(name = "loginServlet", urlPatterns = "/login")

或者

    <servlet>
<servlet-name>loginServlet</servlet-name>
<servlet-class>com.chris.web.servlet.LoginServlet</servlet-class>
</servlet> <servlet-mapping>
<servlet-name>loginServlet</servlet-name>
<url-pattern>/login</url-pattern>
</servlet-mapping>

   4. 使用定义的Servlet

<form action="${pageContext.request.contextPath}/login" method="post">
用户名:<input type="text" name="username"><br/>
密码:<input type="password" name="password"><br/>
<input type="submit" value="登录">
</form>

----------------------------------------------------------------------------------------------------------------

8. JDBC操作数据库

个人理解JDBC:

JDBC是Java应用同数据库交互的一组标准接口,而各大数据库生产商则在JDBC接口的基础上实现各自的数据库驱动,比如com.mysql.jdbc.Driver。

JDBC操作数据库的传统套路如下:

1) 加载驱动程序:

Class.forName("com.mysql.jdbc.Driver");

2) 建立数据库连接:

Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/shiro","root", "");

3) 创建语句对象:

String sql = "select * from users where username=? and password=?";
PreparedStatement ps = connection.prepareStatement(sql);

4) 变量赋值,替换?

ps.setString(1, "Chris");
ps.setString(2, "123");

5) 执行SQL语句并处理ResultSet

ResultSet resultSet = ps.executeQuery();
while (resultSet.next()){
  System.out.println(resultSet.getString(2));
}

6) 关闭相关对象

resultSet.close();
ps.close();
connection.close();

由以上操作步骤可知,在Java应用中,若仅采用JDBC+相应驱动会造成代码的大量重复,并且也很难保证效率。所以在传统的J2EE项目中,采用EJB方式对JDBC封装,但使用起来仍然非常麻烦。由此催生了ORM框架,比如Hibernate, JPA等。Hibernate作为JDBC的轻量级封装,完全采用对象的思想,使得我们在与数据库交互时,更加方便。

----------------------------------------------------------------------------------------------------------------

9. 在JSP和Servlet中有几个地方可以设置编码,各个编码的功能也不一样。

各种编码一览

A. JSP/Servlet都有的编码设置

  1. request.setCharacterEncoding("UTF-8")

  2. response.setCharacterEncoding("UTF-8")

  3. response.setContentType("text/html; charset=UTF-8");

  4. response.setHeader("Content-Type", "text/html; charset=UTF-8");

B. JSP专有的编码设置

  1. <%@ page pageEncoding="UTF-8" %>

  2. <%@ page contentType="text/html; charset=UTF-8" %>

C. HTML页面中的编码设置

  1. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

----------------------------------------------------------------------------------------------------------------

10.