以 / 开始 /a /aa/bbhtml
localhost:8080/项目名称/aa/bbjava
以 / 开始 , 可是以 * 结束 /a/* /*mysql
- 实际上是一个通配符,匹配任意文字
localhost:8080/项目名称/aa/bbweb
写法: 没有/ 以 * 开始 *.扩展名 *.aa *.bbsql
Servlet 上下文数据库
每一个web工程都只有一个ServletContext对象。 说白了也就是无论在哪一个servlet里面,获取到的这个类的对象都是同一个。apache
//1. 获取对象 ServletContext context = getServletContext();
做用数组
获取全局参数浏览器
1. 获取资源在tomcat里面的绝对路径 先获得路径,而后本身new InpuStream context.getRealPath("") //这里获得的是项目在tomcat里面的根目录。 D:\tomcat\apache-tomcat-7.0.52\apache-tomcat-7.0.52\wtpwebapps\Demo03\ String path = context.getRealPath("file/config.properties"); D:\tomcat\apache-tomcat-7.0.52\apache-tomcat-7.0.52\wtpwebapps\Demo03\file\config.properties 2. getResourceAsStream 获取资源 流对象 直接给相对的路径,而后获取流对象。
if (load==true) { int count=0; Object totalcount = getServletContext().getAttribute("count"); if (totalcount!=null) { count=(int) totalcount; } getServletContext().setAttribute("count", count+1); System.out.println("登录成功的次数是"+count+"次"); //设置状态码从新定位 response.setStatus(302); response.setHeader("Location", "load.html");//此处为相对路径 } if (load==false) { response.getWriter().write("登录失败..."); }
细节:tomcat
<!-- A路径: Servlet的路径 http://localhost:8080/Demo4/login B路径: 当前这个html的路径: http://localhost:8080/Demo4/login.html --> <form action="Login" method="get"> 帐号:<input type="text" name="username"/><br> 密码:<input type="text" name="password"/><br> <input type="submit" value="登陆"/> </form>
服务器启动的时候,会为托管的每个web应用程序,建立一个ServletContext对象
从服务器移除托管,或者是关闭服务器。
只要在这个项目里面,均可以取。 只要同一个项目。 A项目 存, 在B项目取,是取不到的? ServletContext对象不一样。
这个对象封装了客户端提交过来的一切数据。
//获得一个枚举集合 Enumeration<String> headerNames = request.getHeaderNames(); while (headerNames.hasMoreElements()) { String name = (String) headerNames.nextElement(); String value = request.getHeader(name); System.out.println(name+"="+value); }
String name = request.getParameter("name"); String address = request.getParameter("address"); System.out.println("name="+name); System.out.println("address="+address); ------------------------------------------------- //name=zhangsan&name=lisi&name=wangwu 一个key能够对应多个值。 Map<String, String[]> map = request.getParameterMap(); Set<String> keySet = map.keySet(); Iterator<String> iterator = keySet.iterator(); while (iterator.hasNext()) { String key = (String) iterator.next(); System.out.println("key="+key + "--的值总数有:"+map.get(key).length); String value = map.get(key)[0]; String value1 = map.get(key)[1]; String value2 = map.get(key)[2]; System.out.println(key+" ======= "+ value + "=" + value1 + "="+ value2); }
客户端提交数据给服务器端,若是数据中带有中文的话,有可能会出现乱码状况,那么能够参照如下方法解决。
1. 代码转码 String username = request.getParameter("username"); String password = request.getParameter("password"); System.out.println("userName="+username+"==password="+password); //get请求过来的数据,在url地址栏上就已经通过编码了,因此咱们取到的就是乱码, //tomcat收到了这批数据,getParameter 默认使用ISO-8859-1去解码 //先让文字回到ISO-8859-1对应的字节数组 , 而后再按utf-8组拼字符串 username = new String(username.getBytes("ISO-8859-1") , "UTF-8"); System.out.println("userName="+username+"==password="+password); 直接在tomcat里面作配置,之后get请求过来的数据永远都是用UTF-8编码。 2. 能够在tomcat里面作设置处理 conf/server.xml 加上URIEncoding="utf-8" <Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443" URIEncoding="UTF-8"/>
这个说的是设置请求体里面的文字编码。 get方式,用这行,有用吗? ---> 没用 request.setCharacterEncoding("UTF-8"); 这行设置必定要写在getParameter以前。
负责返回数据给客户端。
//以字符流的方式写数据 //response.getWriter().write("<h1>hello response...</h1>"); //以字节流的方式写数据 response.getOutputStream().write("hello response2222...".getBytes());
response.getWriter()
//1. 指定输出到客户端的时候,这些文字使用UTF-8编码 response.setCharacterEncoding("UTF-8"); //2. 直接规定浏览器看这份数据的时候,使用什么编码来看。 response.setHeader("Content-Type", "text/html; charset=UTF-8"); response.getWriter().write("我爱黑马训练营...");
response.getOutputStream()
//1. 指定浏览器看这份数据使用的码表 response.setHeader("Content-Type", "text/html;charset=UTF-8"); //2. 指定输出的中文用的码表 response.getOutputStream().write("我爱深圳黑马训练营..".getBytes("UTF-8")); --------------------------------------------
response.setContentType("text/html;charset=UTF-8"); 而后在写数据便可。
让tomcat的默认servlet去提供下载:<br> <a href="download/aa.jpg">aa.jpg</a><br> <a href="download/bb.txt">bb.txt</a><br> <a href="download/cc.rar">cc.rar</a><br>
缘由是tomcat里面有一个默认的Servlet -- DefaultServlet 。这个DefaultServlet 专门用于处理放在tomcat服务器上的静态资源。
html中代码
<h3>手写代码提供下载</h3> <a href="Load?filename=aa.txt">aa.txt</a><br/> <a href="Load?filename=bb.jpg">bb.jpg</a><br/> <a href="Load?filename=cc.zip">cc.zip</a><br/>
建立一个servlet命名为Load,代码
import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; /** * Servlet implementation class Load */ public class Load extends HttpServlet { @SuppressWarnings("resource") protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //得到要下载的文件名 String filename = request.getParameter("filename"); //得到这个文件在tomcat中的绝对路径 String realPath = getServletContext().getRealPath("download/"+filename); //让浏览器收到这个资源的时候,以加载的方式提醒用户而不是直接展现 response.setHeader("Content-Disposition", "attachment;filename="+filename); response.setContentType("text/html;charset=UTF-8"); InputStream fileInputStream = new FileInputStream(realPath); OutputStream fileOutputStream=response.getOutputStream(); byte[] bt=new byte[1024]; int len=0; while ((len=fileInputStream.read(bt)) > -1) { fileOutputStream.write(bt,0,len); } fileInputStream.close(); fileOutputStream.close(); } /** * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) */ protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub doGet(request, response); } }
Servlet注册方式
ServletContext【重点】
做用: 1. 获取全局参数 2. 获取工程里面的资源。 3. 资源共享。 ServletContext 域对象 有几个 一个 何时建立 ? 何时销毁 服务器启动的时候给每个应用都建立一个ServletContext对象, 服务器关闭的时候销毁
简单登陆
HttpServletRequest【重点】
1. 获取请求头 2. 获取提交过来的数据
HttpServletResponse【重点】
负责输出数据到客户端,其实就是对以前的请求做出响应
中文乱码问题。【重点】
下载
1. 完成注册 2. 完成登陆
V1.1 最好配合上数据库,完成注册和登陆的功能。
建立表格存储用户信息,能够规定字符格式之类的,配置JDBC驱动,拷贝JDBC驱动的jar包放在WebContent下的我web-inf下的lib里面右键build path
分析:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Insert title here</title> </head> <body> <!-- 这里action="Login",对应的是servlet配置中的url-pattern --> <form action="Login" method="get"> 姓名:<input type="text" name="username"> 密码:<input type="password" name="password"> <input type="submit" value="注册"> </form> </body> </html>
import java.io.IOException; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import s20190712.Dao.impl.UserImpl; /** * Servlet implementation class Login */ public class Login extends HttpServlet { protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //得到客户端的信息 String username= request.getParameter("username"); String password= request.getParameter("password"); username=new String(username.getBytes("ISO-8859-1"),"UTF-8"); password=new String(password.getBytes("ISO-8859-1"),"UTF-8"); System.out.println("用户名:"+username+"密码:"+password); response.setContentType("text/html;charset=UTF-8"); //校验 if (!username.isEmpty()||!password.isEmpty()) { UserImpl user=new UserImpl(); int insert = user.insert(username, password); if(insert>0) { //设置状态码从新定位 response.setStatus(302); response.setHeader("Location", "config.html");//此处为相对路径 } }else { System.out.println("注册失败"); response.getWriter().write("注册失败..."); } } /** * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) */ protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub doGet(request, response); } }
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Insert title here</title> </head> <body> <h1>您已经成功注册!</h1> <form action="Config" method="post"> 姓名:<input type="text" name="username"> 密码:<input type="password" name="password"> <input type="submit" value="登录"> </form> </body> </html>
import java.io.IOException; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import s20190712.Dao.impl.UserImpl; /** * Servlet implementation class Config */ public class Config extends HttpServlet { protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //得到客户端的信息 request.setCharacterEncoding("utf-8"); String username= request.getParameter("username"); String password= request.getParameter("password"); response.setContentType("text/html;charset=UTF-8"); //校验 if (!username.isEmpty()||!password.isEmpty()) { UserImpl user=new UserImpl(); boolean load = user.load(username, password); if (load==true) { int count=0; Object totalcount = getServletContext().getAttribute("count"); if (totalcount!=null) { count=(int) totalcount; } getServletContext().setAttribute("count", count+1); System.out.println("登录成功的次数是"+count+"次"); //设置状态码从新定位 response.setStatus(302); response.setHeader("Location", "load.html");//此处为相对路径 } if (load==false) { response.getWriter().write("登录失败..."); } }else { response.getWriter().write("请返回页面输入登录信息"); } } /** * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) */ protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub doGet(request, response); } }
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Insert title here</title> </head> <body> <h3>这里有资源能够下载tomcat默认的servlet去提供下载</h3> <a href="download/aa.txt">aa.txt</a><br/> <a href="download/bb.jpg">bb.jpg</a><br/> <a href="download/cc.zip">cc.zip</a><br/> <h3>手写代码提供下载</h3> <a href="Load?filename=aa.txt">aa.txt</a><br/> <a href="Load?filename=bb.jpg">bb.jpg</a><br/> <a href="Load?filename=cc.zip">cc.zip</a><br/> </body> </html>
import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; /** * Servlet implementation class Load */ public class Load extends HttpServlet { @SuppressWarnings("resource") protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //得到要下载的文件名 String filename = request.getParameter("filename"); filename=new String(filename.getBytes("ISO-8859-1"),"UTF-8");//注意这里若是文件名是中文须要对其进行编码处理 //得到这个文件在tomcat中的绝对路径 String realPath = getServletContext().getRealPath("download/"+filename); //让浏览器收到这个资源的时候,以加载的方式提醒用户而不是直接展现 response.setHeader("Content-Disposition", "attachment;filename="+filename); response.setContentType("text/html;charset=UTF-8"); InputStream fileInputStream = new FileInputStream(realPath); OutputStream fileOutputStream=response.getOutputStream(); byte[] bt=new byte[1024]; int len=0; while ((len=fileInputStream.read(bt)) > -1) { fileOutputStream.write(bt,0,len); } fileInputStream.close(); fileOutputStream.close(); } /** * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) */ protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub doGet(request, response); } }
url=jdbc:mysql://localhost:3306/user username=root password=321 driverClass=com.mysql.jdbc.Driver
注意若是出现报错JDBC驱动找不到的状况,两种方法,第一种在Java\jre1.8.0_151\lib\ext中配置JDBC驱动,就没必要在工程目录里面配置了;第二种,注册一下驱动,DriverManager或者Class.forName()均可以
import java.io.InputStream; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.Properties; import com.mysql.jdbc.Driver; public class JDBCUtil { static String driverClass =null; static String url =null; static String username =null; static String password =null; static { try { Properties prop=new Properties(); InputStream is=JDBCUtil.class.getClassLoader().getResourceAsStream("JDBC.properties"); prop.load(is); driverClass = prop.getProperty("driverClass"); url = prop.getProperty("url"); username = prop.getProperty("username"); password = prop.getProperty("password"); } catch (Exception e) { e.printStackTrace(); } } public static Connection getConn() { Connection conn=null; try { //Class.forName(driverClass); conn = DriverManager.getConnection(url,username,password); } catch (Exception e) { e.printStackTrace(); } return conn; } public static void release(Connection conn,Statement st,ResultSet rs) { closeConn(conn); closeRs(rs); closeSt(st); } public static void release(Connection conn,Statement st) { closeConn(conn); closeSt(st); } private static void closeConn(Connection conn) { try { if (conn!=null) { conn.close(); } } catch (SQLException e) { e.printStackTrace(); }finally{ conn=null; } } private static void closeSt(Statement st) { try { if (st!=null) { st.close(); } } catch (SQLException e) { e.printStackTrace(); }finally{ st=null; } } private static void closeRs(ResultSet rs) { try { if (rs!=null) { rs.close(); } } catch (SQLException e) { e.printStackTrace(); }finally{ rs=null; } } }
public interface UserDao { int insert(String username, String password); boolean load(String username, String password); }
import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import com.mysql.jdbc.Statement; import s20190712.jdbc.dao.UserDao; import s20190712.jdbc.util.JDBCUtil; public class UserImpl implements UserDao{ @Override public int insert(String username, String password) { Connection conn=null; PreparedStatement ps=null; int rs =0; try { //1.建立链接对象 conn=JDBCUtil.getConn(); //2.建立preparestatement对象,预处理sql语句 String sql="insert into m_user values(null,?,?)"; ps = conn.prepareStatement(sql);//注意导包import java.sql.PreparedStatement; //3.给占位符赋值 ps.setString(1,username); ps.setString(2,password); //4.执行sql语句 rs = ps.executeUpdate(); if(rs>0){ System.out.println("更新成功"); }else{ System.out.println("更新失败"); } } catch (Exception e) { e.printStackTrace(); }finally { //5.释放资源 JDBCUtil.release(conn,ps); return rs; } } @Override public boolean load(String username, String password) { boolean b=false; Connection conn=null; Statement st=null; ResultSet rs=null; try { //1.建立链接对象 conn=JDBCUtil.getConn(); //2.建立preparestatement对象,预处理sql语句 String sql="select * from m_user where username = ? and password = ?"; PreparedStatement ps = conn.prepareStatement(sql);//注意导包import java.sql.PreparedStatement; //3.给占位符赋值 ps.setString(1,username); ps.setString(2,password); //4.执行sql语句 rs = ps.executeQuery(); if(rs.next()){ b=true; }else{ b=false; } } catch (Exception e) { e.printStackTrace(); }finally { //5.释放资源 JDBCUtil.release(conn,st,rs); return b; } } }