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.