JAVA WEB笔记
Posted ABO
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JAVA WEB笔记相关的知识,希望对你有一定的参考价值。
相关知识点: http协议深入 补充网络协议:
这些内容自Servlet中是可以被操作的;当然在html之中也是可以设置的(head)。
在搞验证码的时候,要刷新验证码的时候,需要访问服务器的Servlet,但是我们知道访问是根据HTTP协议的,而这种方式去请求服务器前,会检查本地有没有这个请求的响应,如果有就从缓存中读取上次的响应的内容,如果这样更新验证码的时候每次都从缓存中取值了,所以一般在刷新请求的时候后面添加一些随机参数,避免重复请求而导致从缓存中取到上次的值。
一、Servlet概述:
1、http的报头很有用,servlet接受到被http协议修饰过的请求,请求和http相关的信息都可以被servlet拿到处理,当然也可以对相应中的内容和http处理。
2、servlet可以预处理不要忘了,init方法执行前,也就是在服务器启动时候,浏览器未访问前预处理些东西。
3、对servlet来说,记住一句话:从客户端发出的请求(http+请求),可以被servlet接受和响应,同时请求信息通常是可以在一个共享容器(ServletContext)内存储和取出。
4、Servlet接口->GenericServlet子类->HttpServlet孙子类
5、Servlet是一个在服务器端运行的JAVA类,其实是服务器通过反射得到的类,因为利用反射才能得到类,所以必须给出类名(在web.xml中配置,服务器在通过解析XML文件得到类名,在反射出类,调用其方法);客户端发出请求,是以http协议发出,因此服务器必须能够解析http和封装的信息,为了更好的方便信息的传递,服务器按照servlet协议实现一系列的“小功能”,ServletContext/包括JSP的内置对象;利用这些“小功能”,不同的功能处理不同内容,例如:response负责封装详响应内容(包括http相关),客户端传递过来的信息被request封装处理(包括http相关),全局容器ServletContext,代表当前WEB应用,所有Servlet共享和request对象都是域对象可以封装数据;它可以获取WEB全局初始化参数、数据共享、访问资源文件:因为我们的程序是放在服务器上的,通常我们不关心文件等资源的路径,但是我们要操作文件,没有路径怎么处理,ServletContext就提供两种方法:
Properties pro= new Properties(); //这里使用getResourceAsStream来读取文件 pro.load(getServletContext().getResourceAsStream("/WEB-INF/classes/db.properties")); //这里使用的传统输入流读取文件,首先还需要用到ServletContext对象获取真实文件路径才行 pro.load(new FileInputStream(getServletContext().getRealPath("/WEB-INF/classes/db.properties")));
这些封装的过程都是服务器自动按照servlet协议自动完成,最后我们只需要拿着这些封装好的内置对象使用即可;
public class PubServlet extends HttpServlet { @Override public void init() throws ServletException { System.out.println("↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓<ABO初始化:预处理开始>↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓"); String servletName=getServletConfig().getServletName(); System.out.println("ABO:---->servletName:【"+servletName+"】"); Enumeration <String > enums=getServletConfig().getInitParameterNames(); while(enums.hasMoreElements()){ String param=enums.nextElement(); String passvalue=getInitParameter(param); System.out.println("ABO:---->ParameterValues:【"+passvalue +"】"); } getServletContext().setAttribute("num", 0); System.out.println("↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑<ABO初始化:预处理结束>↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑"); } public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html;charset=UTF-8"); PrintWriter out = response.getWriter(); System.out.println("↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓<ServletContext示例开始>↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓"); System.out.println("ServletContext:1.获取WEB全局初始化参数。 2.实现数据共享。 3. 读取资源文件 。"); System.out.println("ServletContext获取服务器信息ServerInfo:"+getServletContext().getServerInfo()); System.out.println("ServletContext获取WEB全局初始化参数:"+getServletContext().getInitParameter("servletContext-params")); int num=(Integer) getServletContext().getAttribute("num") ; getServletContext().setAttribute("num", ++num); System.out.println("ServletContext数据共享:"+getServletContext().getAttribute("servletContext-common")); Properties pro= new Properties(); //这里使用getResourceAsStream来读取文件 pro.load(getServletContext().getResourceAsStream("/WEB-INF/classes/db.properties")); System.out.println("ServletContext读取资源文件:"+pro.getProperty("user")+"的密码: "+pro.getProperty("password")+"::"+pro.getProperty("desc")); //这里使用的传统输入流读取文件,首先还需要用到ServletContext对象获取真实文件路径才行 pro.load(new FileInputStream(getServletContext().getRealPath("/WEB-INF/classes/db.properties"))); System.out.println("真实路径为:"+getServletContext().getRealPath("/WEB-INF/classes/db.properties")); System.out.println("ServletContext读取(真实)资源文件:"+pro.getProperty("user")+"的密码: "+pro.getProperty("password")+"::"+pro.getProperty("desc")); System.out.println("↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑<ServletContext示例结束>↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑"); out.println("<!DOCTYPE HTML PUBLIC \\"-//W3C//DTD HTML 4.01 Transitional//EN\\">"); out.println("<meta http-equiv=\\"Content-Type\\">"); out.println("<HTML>"); out.println(" <HEAD><TITLE> abo </TITLE></HEAD>"); out.println(" <BODY>"); out.println(request.getParameter("maixure")+",你牛逼! <br/>大哥! 你是第【"+ getServletContext().getAttribute("num") +"】访问我的人!"); out.println(" <br/><a href=\\"index.jsp\\">back </a> </BODY>"); String strs=request.getParameter("status"); int i=0; if(strs==null){ i=1; }else{ i=Integer.parseInt(strs); } if(i==302){ System.out.println("↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓<HTTP示例开始>↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓"); System.out.println("location与302完成重定向---------开始"); response.setStatus(i); response.setHeader("location", "html/html-pub.html"); System.out.println("location与302完成重定向---------结束"); System.out.println("↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑<HTTP示例结束>↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑"); out.println("</HTML>"); out.flush(); out.close(); } if(i==123){ response.setHeader("refresh", "5;url=html/html-pub.html"); out.println("</HTML>"); out.flush(); out.close(); } else { out.println("<br/>http访问状态(前)"+response.getStatus()+" location:"+response.getLocale()); response.setStatus(201); out.println("<br/>httpcontent内容"+response.getContentType()+"http访问状态(后):"+response.getStatus()); out.println("</HTML>"); out.flush(); out.close(); } } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); } }
二、Servlet:response、request
* response对象
* 响应: * 响应行 * 状态码:void setStatus(int sc) 设置状态码 * 响应头(key:value的形式,一个key对应一个value,一个key对应多个value) * 设置头信息 void setHeader(String name, String value) (一个key对应一个value)经常使用的 setHeader("aa","bb"); setHeader("aa","cc"); 结果:aa:cc void setIntHeader(String name, int value) void setDateHeader(String name, long date) 值是毫秒值(int 秒 long 毫秒) void addHeader(String name, String value) (一个key对应多个value) addHeader("aa","bb"); addHeader("aa","cc"); 结果:aa:bb,cc void addIntHeader(String name, int value) void addDateHeader(String name, long date) * 响应体 ServletOutputStream getOutputStream() 字节输出流 PrintWriter getWriter() 字符输出流
1、重定向(登陆页面)
重定向(登陆页面) * 登陆页面重定向 * 状态码302 应头location * 需求:登陆页面,用户名和密码的登陆页面,用户名和密码都是admin,如果有一个不是,重定向到登陆页面,重新登陆。 // 设置302的状态码 response.setStatus(302); // 设置地址 response.setHeader("location", "/day10/response/login.html"); // response对象提供了一个方法,可以完成重定向。这里面的目录是客户端的绝对路径,因为客户端要再次发送请求 response.sendRedirect("/day10/response/login.html"); public class LoginServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { /** * 先获取用户输入的内容(request对象) * 判断姓名和密码是否都是admin,如果有一个不是,重定向到登陆页面,如果都是,就登陆成功。 */ // 获取用户输入的内容 String username = request.getParameter("username"); // 程序入口 // 获取密码 String password = request.getParameter("password"); // 判断 if("admin".equals(username) && "admin".equals(password)){ // 登陆成功 // 重定向到登陆页面 // response.getWriter().write("success"); response.sendRedirect("/day10/response/refresh.html"); }else{ // 重定向到登陆页面 // 设置302的状态码 //response.setStatus(302); // 设置地址 //response.setHeader("location", "/day10/response/login.html"); // 重定向 response.sendRedirect("/day10/response/login.html"); } } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); } }
2、页面定时刷新(页面读秒操作)
页面定时刷新(页面读秒操作) * 响应的头 refresh response.setHeader("refresh", "5;url=html/html-pub.html"); <meta http-equiv="refresh" content="5;url=/day10/response/login.html"> 禁用浏览器缓存(三个头信息) * 应用:网银。页面的数据是发送变化的。 Cache-Control : no-cache Expires: -1 值是日期类型(setDateHeader()) Pragma : no-cache public class CEPServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { /** * Cache-Control : no-cache Expires: -1 值是日期类型(setDateHeader()) Pragma : no-cache */ // 设置三个头信息 response.setHeader("Cache-Control","no-cache"); response.setHeader("Pragma","no-cache"); response.setDateHeader("Expires", -1); // 向页面输出当前的时间 // 获取当前时间 Date date = new Date(); // 修改格式 yyyy-MM-dd HH:mm:ss SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); String str = sdf.format(date); // 输出 response.getWriter().write(str); } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); } }
3、向页面输出中文(乱码问题)
向页面输出中文(乱码问题) 字节:ServletOutputStream getOutputStream() 字节输出流 * 字节的输出中文的乱码 * * 输出哈罗我的是否乱码呢? * * 不一定乱码。 * * 解决办法 * * 设置浏览器打开文件时所采用的编码 * response.setHeader("Content-Type", "text/html;charset=UTF-8"); * * 获取字符串byte数组时编码和打开文件时编码一致。 * "哈罗我的".getBytes("UTF-8") PrintWriter getWriter() 字符输出流 * 字符输出中文是否乱码呢? * * 肯定乱码 * response缓冲区的编码,默认值ISO-8859-1 * * 设置response缓冲编码 * response.setCharacterEncoding("UTF-8"); * * 设置浏览器打开文件所采用的编码 * response.setHeader("Content-Type", "text/html;charset=UTF-8"); * * 简写方式 * response.setContentType("text/html;charset=UTF-8"); public class OutServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { run2(response); } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); } /** * 字符输出中文是否乱码呢? * * 肯定乱码 * response缓冲区的编码,默认值ISO-8859-1 * * 设置response缓冲编码 * response.setCharacterEncoding("UTF-8"); * * 设置浏览器打开文件所采用的编码 * response.setHeader("Content-Type", "text/html;charset=UTF-8"); * * 简写方式 * response.setContentType("text/html;charset=UTF-8"); * * @param response * @throws IOException */ public void run2(HttpServletResponse response) throws IOException{ // 设置response缓冲区的编码 //response.setCharacterEncoding("UTF-8"); // 设置浏览器打开文件所采用的编码 //response.setHeader("Content-Type", "text/html;charset=UTF-8"); // 简写的形式(等于上面两句) response.setContentType("text/html;charset=UTF-8"); response.getWriter().write("哈罗卧得"); } /** * 字节的输出中文的乱码 * * 输出哈罗我的是否乱码呢? * * 不一定乱码。 * * 解决办法 * * 设置浏览器打开文件时所采用的编码 * response.setHeader("Content-Type", "text/html;charset=UTF-8"); * * 获取字符串byte数组时编码和打开文件时编码一致。 * "哈罗我的".getBytes("UTF-8") * @throws IOException */ public void run1(HttpServletResponse response) throws IOException{ // 设置浏览器打开文件时编码 response.setHeader("Content-Type", "text/html;charset=UTF-8"); // 获取字节输出流 OutputStream os = response.getOutputStream(); // 输出中文 os.write("哈罗我的".getBytes("UTF-8")); } }
* 总结:response对象输出中文,产生乱码。
* 字节 * 解决方案 * 设置浏览器打开文件时采用的编码 response.setHeader("Content-Type", "text/html;charset=UTF-8"); * 获取字符串的byte数组采用的编码 "哈罗我的".getBytes("UTF-8"); * 字符 * 解决方法 * 设置浏览器打开文件时采用的编码 response.setHeader("Content-Type", "text/html;charset=UTF-8"); * 设置response缓冲区的编码 response.setCharacterEncoding("UTF-8"); * 简写的方式(等于上面的两句) * response.setContentType("text/html;charset=UTF-8");
4、实现文件下载(初级的下载)
实现文件下载(初级的下载) * 超链接,浏览器可以解析直接打开。 * 弹出下载窗口。 * 前提条件:先准备一个文件。 * 读取文件,读入到输入流中。 * 通过response读出到浏览器端。 * 设置头信息 * Content-Disposition attachment;filename=文件名称 * 以附件的形式打开。 /** * 文件下载 * @author Administrator * */ public class DownloadServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 先获取到文件,读入输入流中 // 获取文件的绝对磁盘路径 String path = getServletContext().getRealPath("/img/外国美女.jpg"); // 包含文件的名称 c:\\tomcat\\webapps\\day10\\img\\girl7.jpg // 截取文件的名称 girl7.jpg String filename = null; // 获取最后一个\\的位置 int index = path.lastIndexOf("\\\\"); if(index != -1){ filename = path.substring(index+1); } // 判断是什么浏览器 Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; WOW64; Trident/6.0) // Mozilla/5.0 (Windows NT 6.1; WOW64; rv:30.0) Gecko/20100101 Firefox/30.0 String agent = request.getHeader("User-Agent"); // System.out.println(agent); if(agent.contains("MSIE")){ filename = URLEncoder.encode(filename,"UTF-8"); } if(filename != null){ // 设置头信息 response.setHeader("Content-Disposition", "attachment;filename="+filename); System.out.println(request.getRemoteAddr()); System.out.println(path); InputStream in = new FileInputStream(path); // 通过response读出到客户端 OutputStream os = response.getOutputStream(); // io的拷贝 byte [] b = new byte[1024]; int len = 0; while((len = in.read(b)) != -1){ os.write(b, 0, len); } in.close(); // os.close();服务器管理流 } } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); } }
5、实现验证码
/** * 验证码 * @author Administrator * */ public class CheckcodeServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { /** * 在内存中生成图片(纸),没有设置背景颜色,画填充的矩形,并且和纸的大小相同,矩形有颜色。 * 获取笔的对象(设置颜色,设置字体,画字符串,画矩形) * 先准备好数据,随机生成4个字符,把字符画到纸上 * 画干扰线 * 把内存中的图片输出到客户端上 */ int width = 120; int height = 30; // 在内存中生成图片 BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB); // 先获取画笔对象 Graphics2D g = (Graphics2D) image.getGraphics(); // 设置灰色 g.setColor(Color.GRAY); // 画填充的矩形 g.fillRect(0, 0, width, height); // 设置颜色 g.setColor(Color.BLUE); // 画边框 g.drawRect(0, 0, width-1, height-1); // 准备数据,随机获取4个字符 // String words = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890"; String words = "\\u7684\\u4e00\\u4e86\\u662f\\u6211\\u4e0d\\u5728\\u4eba\\u4eec\\u6709\\u6765\\u4ed6\\u8fd9\\u4e0a\\u7740\\u4e2a\\u5730\\u5230\\u5927\\u91cc\\u8bf4\\u5c31\\u53bb\\u5b50\\u5f97\\u4e5f\\u548c\\u90a3\\u8981\\u4e0b\\u770b\\u5929\\u65f6\\u8fc7\\u51fa\\u5c0f\\u4e48\\u8d77\\u4f60\\u90fd\\u628a\\u597d\\u8fd8\\u591a\\u6ca1\\u4e3a\\u53c8\\u53ef\\u5bb6\\u5b66\\u53ea\\u4ee5\\u4e3b\\u4f1a\\u6837\\u5e74\\u60f3\\u751f\\u540c\\u8001\\u4e2d\\u5341\\u4ece\\u81ea\\u9762\\u524d\\u5934\\u9053\\u5b83\\u540e\\u7136\\u8d70\\u5f88\\u50cf\\u89c1\\u4e24\\u7528\\u5979\\u56fd\\u52a8\\u8fdb\\u6210\\u56de\\u4ec0\\u8fb9\\u4f5c\\u5bf9\\u5f00\\u800c\\u5df1\\u4e9b\\u73b0\\u5c71\\u6c11\\u5019\\u7ecf\\u53d1\\u5de5\\u5411\\u4e8b\\u547d\\u7ed9\\u957f\\u6c34\\u51e0\\u4e49\\u4e09\\u58f0\\u4e8e\\u9ad8\\u624b\\u77e5\\u7406\\u773c\\u5fd7\\u70b9\\u5fc3\\u6218\\u4e8c\\u95ee\\u4f46\\u8eab\\u65b9\\u5b9e\\u5403\\u505a\\u53eb\\u5f53\\u4f4f\\u542c\\u9769\\u6253\\u5462\\u771f\\u5168\\u624d\\u56db\\u5df2\\u6240\\u654c\\u4e4b\\u6700\\u5149\\u4ea7\\u60c5\\u8def\\u5206\\u603b\\u6761\\u767d\\u8bdd\\u4e1c\\u5e2d\\u6b21\\u4eb2\\u5982\\u88ab\\u82b1\\u53e3\\u653e\\u513f\\u5e38\\u6c14\\u4e94\\u7b2c\\u4f7f\\u5199\\u519b\\u5427\\u6587\\u8fd0\\u518d\\u679c\\u600e\\u5b9a\\u8bb8\\u5feb\\u660e\\u884c\\u56e0\\u522b\\u98de\\u5916\\u6811\\u7269\\u6d3b\\u90e8\\u95e8\\u65e0\\u5f80\\u8239\\u671b\\u65b0\\u5e26\\u961f\\u5148\\u529b\\u5b8c\\u5374\\u7ad9\\u4ee3\\u5458\\u673a\\u66f4\\u4e5d\\u60a8\\u6bcf\\u98ce\\u7ea7\\u8ddf\\u7b11\\u554a\\u5b69\\u4e07\\u5c11\\u76f4\\u610f\\u591c\\u6bd4\\u9636\\u8fde\\u8f66\\u91cd\\u4fbf\\u6597\\u9a6c\\u54ea\\u5316\\u592a\\u6307\\u53d8\\u793e\\u4f3c\\u58eb\\u8005\\u5e72\\u77f3\\u6ee1\\u65e5\\u51b3\\u767e\\u539f\\u62ff\\u7fa4\\u7a76\\u5404\\u516d\\u672c\\u601d\\u89e3\\u7acb\\u6cb3\\u6751\\u516b\\u96be\\u65e9\\u8bba\\u5417\\u6839\\u5171\\u8ba9\\u76f8\\u7814\\u4eca\\u5176\\u4e66\\u5750\\u63a5\\u5e94\\u5173\\u4fe1\\u89c9\\u6b65\\u53cd\\u5904\\u8bb0\\u5c06\\u5343\\u627e\\u4e89\\u9886\\u6216\\u5e08\\u7ed3\\u5757\\u8dd1\\u8c01\\u8349\\u8d8a\\u5b57\\u52a0\\u811a\\u7d27\\u7231\\u7b49\\u4e60\\u9635\\u6015\\u6708\\u9752\\u534a\\u706b\\u6cd5\\u9898\\u5efa\\u8d76\\u4f4d\\u5531\\u6d77\\u4e03\\u5973\\u4efb\\u4ef6\\u611f\\u51c6\\u5f20\\u56e2\\u5c4b\\u79bb\\u8272\\u8138\\u7247\\u79d1\\u5012\\u775b\\u5229\\u4e16\\u521a\\u4e14\\u7531\\u9001\\u5207\\u661f\\u5bfc\\u665a\\u8868\\u591f\\u6574\\u8ba4\\u54cd\\u96ea\\u6d41\\u672a\\u573a\\u8be5\\u5e76\\u5e95\\u6df1\\u523b\\u5e73\\u4f1f\\u5fd9\\u63d0\\u786e\\u8fd1\\u4eae\\u8f7b\\u8bb2\\u519c\\u53e4\\u9ed1\\u544a\\u754c\\u62c9\\u540d\\u5440\\u571f\\u6e05\\u9633\\u7167\\u529e\\u53f2\\u6539\\u5386\\u8f6c\\u753b\\u9020\\u5634\\u6b64\\u6cbb\\u5317\\u5fc5\\u670d\\u96e8\\u7a7f\\u5185\\u8bc6\\u9a8c\\u4f20\\u4e1a\\u83dc\\u722c\\u7761\\u5174\\u5f62\\u91cf\\u54b1\\u89c2\\u82e6\\u4f53\\u4f17\\u901a\\u51b2\\u5408\\u7834\\u53cb\\u5ea6\\u672f\\u996d\\u516c\\u65c1\\u623f\\u6781\\u5357\\u67aa\\u8bfb\\u6c99\\u5c81\\u7ebf\\u91ce\\u575a\\u7a7a\\u6536\\u7b97\\u81f3\\u653f\\u57ce\\u52b3\\u843d\\u94b1\\u7279\\u56f4\\u5f1f\\u80dc\\u6559\\u70ed\\u5c55\\u5305\\u6b4c\\u7c7b\\u6e10\\u5f3a\\u6570\\u4e61\\u547c\\u6027\\u97f3\\u7b54\\u54e5\\u9645\\u65e7\\u795e\\u5ea7\\u7ae0\\u5e2e\\u5566\\u53d7\\u7cfb\\u4ee4\\u8df3\\u975e\\u4f55\\u725b\\u53d6\\u5165\\u5cb8\\u6562\\u6389\\u5ffd\\u79cd\\u88c5\\u9876\\u6025\\u6797\\u505c\\u606f\\u53e5\\u533a\\u8863\\u822c\\u62a5\\u53f6\\u538b\\u6162\\u53d4\\u80cc\\u7ec6"; // 设置颜色 g.setColor(Color.YELLOW); // 设置字体 g.setFont(new Font("隶书", Font.BOLD, 20)); Random random = new Random(); int x = 20; int y = 20; for(int i=0;i<4;i++){ // void rotate(double theta, double x, double y) // theta 弧度 // hudu = jiaodu * Math.PI / 180; // 获取正负30之间的角度 int jiaodu = random.nextInt(60)-30; double hudu = jiaodu * Math.PI / 180; g.rotate(hudu, x, y); // 获取下标 int index = random.nextInt(words.length()); // 返回指定下标位置的字符,随机获取下标 char ch = words.charAt(index); // 写字符串 g.drawString(""+ch, x, y); g.rotate(-hudu, x, y); x += 20; } // 设置颜色 g.setColor(Color.GREEN); int x1,x2,y1,y2; // 画干扰线 for(int i=0;i<4;i++){ x1 = random.nextInt(width); y1 = random.nextInt(height); x2 = random.nextInt(width); y2 = random.nextInt(height); g.drawLine(x1, y1, x2, y2); } // 输出到客户端 ImageIO.write(image, "jpg", response.getOutputStream()); } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); } public static void main(String[] args) { System.out.println("\\u9fa5"); System.out.println("\\u9fa4"); System.out.println("\\u9fa3"); System.out.println("\\u9fa2"); } }
* request对象
客户端通过HTTP访问服务器(Servlet),所携带的所有信息都是封装在这个对象中的。
获取客户机信息 getRemoteAddr(*****) 获取IP地址 getMethod() (*****) 获取请求方式 getContextPath()(*****) 获取虚拟路径 获取请求头信息 String getHeader(String name) long getDateHeader(String name) int getIntHeader(String name) * 请求头 referer 记住当前网页的来源 User-Agent 判断浏览器 if-modified-since 控制缓存 获取请求参数(*****) String getParameter(String name) (*****) String[] getParameterValues(String name)(*****) Map getParameterMap()(*****) Enumeration getParameterNames()(用的比较少)
乱码问题解决:
* POST请求乱码 :request.setCharacterEncoding("utf-8"); * GET请求乱码 解决方案一:修改tomcat/conf/server.xml <Connector port="80" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" URIEncoding="utf-8"/> * 必须有修改tomcat服务器配置文件权限 解决方案二:逆向编解码 username = URLEncoder.encode(username, "ISO8859-1"); username = URLDecoder.decode(username, "utf-8"); 解决方案三:简写的方式(推荐使用) username = new String(username.getBytes("ISO-8859-1"),"utf-8"); * request获取中文数据乱码(总结:) * post提交 -->由于POST请求方式是封装在包体内的,整个信息都封装在request中,所以设置编码使用request的方法。 * 设置request缓冲区的编码 request.setCharacterEncoding("utf-8"); * get提交-->GET的请求方式是不在包体,是附加在URL之后的,从浏览器中发出请求后经过服务器,服务器的编码通常ISO-8859-1又给编码转换了,所以这里要逆向编码即可。 * String构造方法 username = new String(username.getBytes("ISO-8859-1"),"utf-8");
重定向和转发的区别(*****)
* getRequestDispatcher(String path) ,返回是RequestDispatcher对象 * RequestDispatcher: forward(ServletRequest request, ServletResponse response)(经常使用) 转发的方法 include(ServletRequest request, ServletResponse response)(了解) 包含 // 完成重定向的工作(客户端端绝对路径),两次请求,两次响应;这种情况下request这个域对象中的数据就没了。 response.sendRedirect("/day10/request4"); response.sendRedirect("zhifubao.com"); // 转发(路径服务器的绝对路径),一次请求,一次响应; request.getRequestDispatcher("/request4").forward(request, response);
三、两个会话的技术
* cookie( 浏览器端)
* cookie的构造方法 new Cookie("cookie的名称","cookie的值"); * 获取cookie的名称:getName(); * 获取cookie的值:getValue(); * 会话级别cookie * 持久的cookie * setMaxAge(int 秒) 设置有效时间 * setPath() 设置有效路径 * 默认的路径 /day11 /day11/servet * 访问其他的web资源 http://localhost/day11/jsp/1.jsp * setDomain() 设置有效域名 * 持久的cookie失效 setMaxAge(0) 有效路径相同 * request.getCookies() 返回cookie数组 * response.addCookie(new Cookie()) 回写cookie
* session(服务器端)
* 为每个浏览器创建独享的session空间。分配jsessionid ,基于cookie。 * 获取session对象:request.getSession() 第一次访问,创建session。 * HttpSession对象 * getId(); * invalidate() 销毁session * session的追踪(了解) * session的创建和销毁 * 第一次访问资源,调用request.getSession(),创建session *以上是关于JAVA WEB笔记的主要内容,如果未能解决你的问题,请参考以下文章maven web项目的web.xml报错The markup in the document following the root element must be well-formed.(代码片段